java中的算法

上传人:痛*** 文档编号:194757386 上传时间:2023-03-13 格式:PDF 页数:14 大小:136.03KB
收藏 版权申诉 举报 下载
java中的算法_第1页
第1页 / 共14页
java中的算法_第2页
第2页 / 共14页
java中的算法_第3页
第3页 / 共14页
资源描述:

《java中的算法》由会员分享,可在线阅读,更多相关《java中的算法(14页珍藏版)》请在装配图网上搜索。

1、插入排序:package org.rut.util.algorithm.support;import org.rut.util.algorithm.SortUtil;publicclass InsertSort implements SortUtil.Sort/*(non-Javadoc)*see org.rut.util.algorithm.SortUtil.Sort#sort(int)*/publicvoid sort(int data)int temp;for(int i=1;i0)&(datajdataj-1);j-)SortUtil.swap(data,j,j-1);冒泡排序:pac

2、kage org.rut.util.algorithm.support;import org.rut.util.algorithm.SortUtil;publicclass BubbleSort implements SortUtil.Sort/*(non-Javadoc)*see org.rut.util.algorithm.SortUtil.Sort#sort(int)*/publicvoid sort(int data)int temp;for(int i=0;ii;j-)if(datajdataj-1)SortUtil.swap(data,j,j-1);选择排序:package org

3、.rut.util.algorithm.support;import org.rut.util.algorithm.SortUtil;publicclass SelectionSort implements SortUtil.Sort publicvoid sort(int data)int temp;for (int i=0;i i;j-)if (dataj 2;i/=2)for(int j=0;ji;j+)insertSort(data,j,i);insertSort(data,0,1);privatevoid insertSort(int data,int start,int inc)i

4、nt temp;for(int i=start+inc;i=inc)&(dataj1)quickSort(data,i,k-1);if(j-k)1)quickSort(data,k+1,j);privateint partition(int data,int l,int r,int pivot)do while(data+lpivot);SortUtil.swap(data,l,r);while(l0)int j=stacktop-;int i=stacktop-;pivotIndex=(i+j)/2;pivot=datapivotIndex;SortUtil.swap(data,pivotI

5、ndex,j);/partition l=i-1;r=j;do while(data+lpivot);SortUtil.swap(data,l,r);while(lTHRESHOLD)stack+top=i;stack+top=l-1;if(j-l)THRESHOLD)stack+top=l+1;stack+top=j;/new InsertSort().sort(data);insertSort(data);privatevoid insertSort(int data)int temp;for(int i=1;i0)&(datajdataj-1);j-)SortUtil.swap(data

6、,j,j-1);归并排序:package org.rut.util.algorithm.support;import org.rut.util.algorithm.SortUtil;lass MergeSort implements SortUtil.Sort publicvoid sort(int data)int temp=new int data.length;mergeSort(data,temp,0,data.length-1);privatevoid mergeSort(int data,int temp,int l,int r)int mid=(l+r)/2;if(l=r)ret

7、urn;mergeSort(data,temp,l,mid);mergeSort(data,temp,mid+1,r);for(int i=l;i=r;i+)temp=data;int i1=l;int i2=mid+1;for(int cur=l;curr)datacur=tempi1+;elseif(tempi1=THRESHOLD)mergeSort(data,temp,l,mid);else insertSort(data,l,mid-l+1);if (r-mid)THRESHOLD)mergeSort(data,temp,mid+1,r);else insertSort(data,m

8、id+1,r-mid);for (i=l;i=mid;i+)temp=data;for (j=1;j=r-mid;j+)tempr-j+1=dataj+mid;int a=templ;int b=tempr;for (i=l,j=r,k=l;k=r;k+)if (a b)datak=tempi+;a=temp;else datak=tempj-;b=tempj;privatevoid insertSort(int data,int start,int len)for(int i=start+1;istart)&datajdataj-1;j-)SortUtil.swap(data,j,j-1);

9、堆排序:package org.rut.util.algorithm.support;import org.rut.util.algorithm.SortUtil;publicclass HeapSort implements SortUtil.Sort publicvoid sort(int data)MaxHeap h=new MaxHeap();h.init(data);for(int i=0;idata.length;i+)h.remove();System.arraycopy(h.queue,1,data,0,data.length);privatestaticclass MaxHe

10、ap void init(int data)this.queue=new int data.length+1;for(int i=0;idata.length;i+)queue+size=data;fixUp(size);privateint size=0;privateint queue;publicint get()return queue1;publicvoid remove()SortUtil.swap(queue,1,size-);fixDown(1);/fixdownprivatevoid fixDown(int k)int j;while (j=k 1)=size)if (j s

11、ize&queuejqueuej)/不用交换break;SortUtil.swap(queue,j,k);k=j;privatevoid fixUp(int k)while (k 1)int j=k 1;if (queuejqueuek)break;SortUtil.swap(queue,j,k);k=j;SortUtil:package org.rut.util.algorithm;import org.rut.util.algorithm.support.BubbleSort;import org.rut.util.algorithm.support.HeapSort;import org

12、.rut.util.algorithm.support.ImprovedMergeSort;import org.rut.util.algorithm.support.ImprovedQuickSort;import org.rut.util.algorithm.support.InsertSort;import org.rut.util.algorithm.support.MergeSort;import org.rut.util.algorithm.support.QuickSort;import org.rut.util.algorithm.support.SelectionSort;i

13、mport org.rut.util.algorithm.support.ShellSort;/*author treeroot *since 2006-2-2 *version 1.0 */publicclass SortUtil publicfinalstaticint INSERT=1;publicfinalstaticint BUBBLE=2;publicfinalstaticint SELECTION=3;publicfinalstaticint SHELL=4;publicfinalstaticint QUICK=5;publicfinalstaticint IMPROVED_QU

14、ICK=6;publicfinalstaticint MERGE=7;publicfinalstaticint IMPROVED_MERGE=8;publicfinalstaticint HEAP=9;publicstaticvoid sort(int data)sort(data,IMPROVED_QUICK);privatestaticString name=insert,bubble,selection,shell,quick,improved_quick,merge,improved_merge,heap ;privatestatic Sort impl=new Sort new In

15、sertSort(),new BubbleSort(),new SelectionSort(),new ShellSort(),new QuickSort(),new ImprovedQuickSort(),new MergeSort(),new ImprovedMergeSort(),new HeapSort();publicstaticString to String(int algorithm)return namealgorithm-1;publicstaticvoid sort(int data,int algorithm)implalgorithm-1.sort(data);publicstaticinterface Sort publicvoid sort(int data);publicstaticvoid swap(int data,int i,int j)int temp=data;data=dataj;dataj=temp;

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!