Java排序源代码.docx

上传人:b****6 文档编号:8261165 上传时间:2023-01-30 格式:DOCX 页数:15 大小:21.11KB
下载 相关 举报
Java排序源代码.docx_第1页
第1页 / 共15页
Java排序源代码.docx_第2页
第2页 / 共15页
Java排序源代码.docx_第3页
第3页 / 共15页
Java排序源代码.docx_第4页
第4页 / 共15页
Java排序源代码.docx_第5页
第5页 / 共15页
点击查看更多>>
下载资源
资源描述

Java排序源代码.docx

《Java排序源代码.docx》由会员分享,可在线阅读,更多相关《Java排序源代码.docx(15页珍藏版)》请在冰豆网上搜索。

Java排序源代码.docx

Java排序源代码

一、插入排序

Ø直接插入排序:

InsertSort

排序方法最好时间平均时间最坏时间辅助空间稳定性

直接插入排序O(n)O(n2)O(n2)O

(1)稳定

直接插入排序的基本思想是:

顺序地把待排序的数据元素按其值的大小插入到已排序数据元素子集合的适当位置。

子集合的数据元素个数从只有一个数据元素开始逐次增大。

当子集合大小最终和集合大小相同时排序完毕。

publicclassInsertSort{

publicstaticvoidinsertSort(int[]a){

inti,j,temp;

intn=a.length;

for(i=0;i

temp=a[i+1];

j=i;

while(j>-1&&temp<=a[j]){

a[j+1]=a[j];

j--;

}

a[j+1]=temp;

}

}

publicstaticvoidmain(String[]args){

int[]test={64,5,7,89,6,24};

intn=test.length;

insertSort(test);

for(inti=0;i

System.out.print(test[i]+"");

}

}

Ø折半插入排序:

BinSort这般查找必须是有序的数组

publicclassBinSort{

/**

*@paramargs

*/

publicstaticvoidmain(String[]args){

intarr[]=newint[]{1,12,24,32,41,65,76,478,483,};

//用户输入查找的内容

System.out.println("请输入要查找的数值:

");

Scannerinput=newScanner(System.in);

inttarget=input.nextInt();

//搜索开始时,查找范围的上下边界、中间元素的索引

inthigh=arr.length-1;

intlow=0;

intmid=(high+low)/2;

//开始查找

while(low<=high&&arr[mid]!

=target){

if(target>arr[mid]){

//目标比中值大,向上收缩搜索范围

low=mid+1;

}else{

//目标比中值小,向下收缩搜索范围

high=mid-1;

}

//重新设定中间元素的索引

mid=(low+high)/2;

}

if(low>high){

System.out.println("目标不在数组中!

");

}else{

System.out.println("目标在数组中第"+(mid+1)+"个位置!

");

}

}

}

Ø希尔排序:

ShellSort

排序方法最好时间平均时间最坏时间辅助空间稳定性

希尔排序O(n1.3)O

(1)不稳定

希尔排序的基本思想是:

把待排序的数据元素分成若干个小组,对同一小组内的数据元素用直接插入法排序;小组的个数逐次缩小;当完成了所有数据元素都在一个组内的排序后排序过程结束。

希尔排序又称作缩小增量排序。

publicclassShellSort{

publicstaticvoidshellSort(int[]a,int[]d,intnumOfD){

inti,j,k,m,span;

inttemp;

intn=a.length;

for(m=0;m

span=d[m];//取本次的增量值

for(k=0;k

for(i=k;i

temp=a[i+span];

j=i;

while(j>-1&&temp<=a[j]){

a[j+span]=a[j];

j=j-span;

}

a[j+span]=temp;

}

}

}

}

publicstaticvoidmain(String[]args){

int[]test={65,34,25,87,12,38,56,46,14,77,92,23};

intn=test.length;

intnumOfD=3;

int[]d={6,3,1};

shellSort(test,d,numOfD);

for(inti=0;i

System.out.print(test[i]+"");

}

}

二、选择排序

选择排序的基本思想是:

每次从待排序的数据元素集合中选取最小(或最大)的数据元素放到数据元素集合的最前(或最后),数据元素集合不断缩小,当数据元素集合为空时排序过程结束。

常用的选择排序有直接选择排序和堆排序两种。

堆排序是一种基于完全二叉树的排序。

Ø直接选择排序:

直接选择排序的基本思想是:

从待排序的数据元素集合中选取最小的数据元素并将它与原始数据元素集合中的第一个数据元素交换位置;然后从不包括第一个位置上数据元素的集合中选取最小的数据元素并将它与原始数据元素集合中的第二个数据元素交换位置;如此重复,直到数据元素集合中只剩一个数据元素为止。

(1)publicclassSelectSort{

publicstaticvoidselectSort(int[]a){

inti,j,small;

inttemp;

intn=a.length;

for(i=0;i

small=i;//设第i个数据元素最小

for(j=i+1;j

//寻找最小的数据元素

if(a[j]

small=j;//记住最小元素的下标

if(small!

=i){//当最小元素的下标不为i时交换位置

temp=a[i];

a[i]=a[small];

a[small]=temp;

}

}

}

publicstaticvoidmain(String[]args){

int[]test={64,5,7,89,6,24};

intn=test.length;

selectSort(test);

for(inti=0;i

System.out.print(test[i]+"");

}

}

(2)稳定的直接选择排序

排序方法最好时间平均时间最坏时间辅助空间稳定性

直接选择排序O(n2)O(n2)O(n2)O

(1)稳定

直接选择排序的基本思想是:

从待排序的数据元素集合中选取最小的数据元素并将它与原始数据元素集合中的第一个数据元素交换位置;然后从不包括第一个位置上数据元素的集合中选取最小的数据元素并将它与原始数据元素集合中的第二个数据元素交换位置;如此重复,直到数据元素集合中只剩一个数据元素为止。

publicclassSelectSort2{

publicstaticvoidselectSort2(inta[]){

inti,j,small;

inttemp;

intn=a.length;

for(i=0;i

small=i;

for(j=i+1;j

if(a[j]

small=j;//记住最小元素的下标

}

if(small!

=i){

temp=a[small];

for(j=small;j>i;j--)

//把该区段尚未排序元素依次后移

a[j]=a[j-1];

a[i]=temp;//插入找出的最小元素

}

}

}

publicstaticvoidmain(String[]args){

int[]test={64,5,7,89,6,24,5};

intn=test.length;

selectSort2(test);

for(inti=0;i

System.out.print(test[i]+"");

}

}

Ø堆排序:

HeapSort

排序方法最好时间平均时间最坏时间辅助空间稳定性

堆排序O(nlog2n)O(nlog2n)O(nlog2n)O

(1)不稳定

在直接选择排序中,放在数组中的n个数据元素排成一个线性序列(即线性结构),要从有n个数据元素的数组中选择出一个最小的数据元素需要比较n-1次。

如果能把待排序的数据元素集合构成一个完全二叉树结构,则每次选择出一个最大(或最小)的数据元素只需比较完全二叉树的高度次,即log2n次,则排序算法的时间复杂度就是O(nlog2n)。

这就是堆排序的基本思想。

堆排序的基本思想是:

循环执行如下过程直到数组为空:

(1)把堆顶a[0]元素(最大元素)和当前最大堆的最后一个元素交换;

(2)最大堆元素个数减1;(3)调整根结点使之满足最大堆的定义。

最大堆的定义如下:

设数组a中存放了n个数据元素,数组下标从0开始,如果当数组下标2i+1

a[i]≥a[2i+1];如果当数组下标2i+2

a[i]≥a[2i+2],则这样的数据结构称为最大堆。

最小堆的定义如下:

设数组a中存放了n个数据元素,数组下标从0开始,如果当数组下标2i+1

a[i]≤a[2i+1];如果当数组下标2i+2

a[i]≤a[2i+2],则这样的数据结构称为最小堆。

publicclassHeapSort{

publicstaticvoidcreateHeap(int[]a,intn,inth){

inti,j,flag;

inttemp;

i=h;//i为要建堆的二叉树根结点下标

j=2*i+1;//j为i结点的左孩子结点的下标

temp=a[i];

flag=0;

//沿左右孩子中值较大者重复向下筛选

while(j

=1){

//寻找左右孩子结点中的较大者,j为其下标

if(j

j++;

if(temp>a[j])//a[i]>a[j]

flag=1;//标记结束筛选条件

else{//否则把a[j]上移

a[i]=a[j];

i=j;

j=2*i+1;

}

}

a[i]=temp;//把最初的a[i]赋予最后的a[j]

}

publicstaticvoidinitCreateHeap(int[]a){

intn=a.length;

for(inti=(n-1)/2;i>=0;i--)

createHeap(a,n,i);

}

publicstaticvoidheapSort(int[]a){

inttemp;

intn=a.length;

initCreateHeap(a);//初始化创建最大堆

for(inti=n-1;i>0;i--){//当前最大堆个数每次递减1

//把堆顶a[0]元素和当前最大堆的最后一个元素交换

temp=a[0];

a[0]=a[i];

a[i]=temp;

createHeap(a,i,0);//调整根结点满足最大堆

}

}

publicstaticvoidmain(String[]args){

int[]test={10,50,32,5,76,9,40,88};

intn=test.length;

heapSort(test);

for(inti=0;i

System.out.print(test[i]+"");

}

}

三、交换排序

Ø冒泡排序:

BubbleSort

排序方法最好时间平均时间最坏时间辅助空间稳定性

冒泡排序O(n)O(n2)O(n2)O

(1)稳定

冒泡排序的基本思想是:

设数组a中存放了n个数据元素,循环进行n-1趟如下的排序过程:

第1趟时,依次比较相临两个数据元素a[i]和a[i+1](i=0,1,2,…,n-2),若为逆序,即a[i]>a[i+1],则交换两个数据元素,否则不交换,这样数值最大的数据元素将被放置在a[n-1]中。

第2趟时,循环次数减1,即数据元素个数为n-1,操作方法和第1趟的类似,这样整个n个数据元素集合中数值次大的数据元素将被放置在a[n-2]中。

当第n-1趟结束时,整个n个数据元素集合中次小的数据元素将被放置在a[1]中,a[0]中放置了最小的数据元素。

publicclassBubbleSort{

publicstaticvoidbubbleSort(int[]a){

inti,j,flag=1;

inttemp;

intn=a.length;

for(i=1;i

flag=0;

for(j=0;j

if(a[j]>a[j+1]){

flag=1;

temp=a[j];

a[j]=a[j+1];

a[j+1]=temp;

}

}

}

}

publicstaticvoidmain(String[]args){

int[]test={64,5,7,89,6,24};

intn=test.length;

bubbleSort(test);

for(inti=0;i

System.out.print(test[i]+"");

}

}

Ø快速排序:

QuickSort

排序方法最好时间平均时间最坏时间辅助空间稳定性

快速排序O(nlog2n)O(nlog2n)O(n2)O(log2n)不稳定

快速排序是一种二叉树结构的交换排序方法。

快速排序算法的基本思想是:

设数组a中存放了n个数据元素,low为数组的低端下标,high为数组的高端下标,从数组a中任取一个元素(通常取a[low])做为标准元素,以该标准元素调整数组a中其他各个元素的位置,使排在标准元素前面的元素均小于标准元素,排在标准元素后面的均大于或等于标准元素。

这样一次排序过程结束后,一方面将标准元素放在了未来排好序的数组中该标准元素应位于的位置上,另一方面将数组中的元素以标准元素为中心分成了两个子数组,位于标准元素左边子数组中的元素均小于标准元素,位于标准元素右边子数组中的元素均大于等于或标准元素。

对这两个子数组中的元素分别再进行方法类同的递归快速排序。

算法的递归出口条件是low≥high。

publicclassQuickSort{

publicstaticvoidQuickSort(int[]a,intlow,inthigh){

inti,j;

inttemp;

i=low;

j=high;

temp=a[low];//取第一个元素为标准数据元素

while(i

//在数组的右端扫描

while(i

j--;

if(i

a[i]=a[j];

i++;

}

//在数组的左端扫描

while(i

i++;

if(i

a[j]=a[i];

j--;

}

}

a[i]=temp;

if(low

QuickSort(a,low,i-1);//对左端子集合递归

if(i

QuickSort(a,j+1,high);//对右端子集合递归

}

publicstaticvoidmain(String[]args){

int[]test={60,55,48,37,10,90,84,36};

intn=8;

QuickSort(test,0,7);

for(inti=0;i

System.out.print(test[i]+"");

}

}

四、归并排序

排序方法最好时间平均时间最坏时间辅助空间稳定性

归并排序O(nlog2n)O(nlog2n)O(nlog2n)O(n)稳定

Ø归并排序:

MergeSort

归并排序主要是二路归并排序。

二路归并排序的基本思想是:

设数组a中存放了n个数据元素,初始时我们把它们看成是n个长度为1的有序子数组,然后从第一个子数组开始,把相临的子数组两两合并,得到n/2个(若n/2为小数则上取整)长度为2的新的有序子数组(当n为奇数时最后一个新的有序子数组的长度为1);对这些新的有序子数组再两两归并;如此重复,直到得到一个长度为n的有序数组为止。

多于二路的归并排序方法和二路归并排序方法类同。

publicclassMergeSort{

publicstaticvoidmerge(int[]a,int[]swap,intk){

intn=a.length;

intm=0,u1,l2,i,j,u2;

intl1=0;//第一个有序子数组下界为0

while(l1+k<=n-1){

l2=l1+k;//计算第二个有序子数组下界

u1=l2-1;//计算第一个有序子数组上界

u2=(l2+k-1<=n-1)?

l2+k-1:

n-1;//计算第二个有序子数组上界

for(i=l1,j=l2;i<=u1&&j<=u2;m++){

if(a[i]<=a[j]){

swap[m]=a[i];

i++;

}else{

swap[m]=a[j];

j++;

}

}

//子数组2已归并完,将子数组1中剩余的元素存放到数组swap中

while(i<=u1){

swap[m]=a[i];

m++;

i++;

}

//子数组1已归并完,将子数组2中剩余的元素存放到数组swap中

while(j<=u2){

swap[m]=a[j];

m++;

j++;

}

l1=u2+1;

}

//将原始数组中只够一组的数据元素顺序存放到数组swap中

for(i=l1;i

swap[m]=a[i];

}

publicstaticvoidmergeSort(int[]a){

inti;

intn=a.length;

intk=1;//归并长度从1开始

int[]swap=newint[n];

while(k

merge(a,swap,k);//调用函数merge()

for(i=0;i

a[i]=swap[i];//将元素从临时数组swap放回数组a中

k=2*k;//归并长度加倍

}

}

publicstaticvoidmain(String[]args){

int[]test={72,73,71,23,94,16,5,68,46};

;

intn=test.length;

mergeSort(test);

for(inti=0;i

System.out.print(test[i]+"");

}

}

五、基数排序

排序方法最好时间平均时间最坏时间辅助空间稳定性

基数排序O(mn)O(mn)O(mn)O(n)稳定

基数排序算法的基本思想是:

设待排序的数据元素是m位d进制整数(不足m位的在高位补0),设置d个桶,令其编号分别为0,1,2,…,d-1。

首先按最低位(即个位)的数值依次把各数据元素放到相应的桶中,然后按照桶号从小到大和进入桶中数据元素的先后次序收集分配在各桶中的数据元素,这样就形成了数据元素集合的一个新的排列,我们称这样的一次排序过程为一次基数排序;再对一次基数排序得到的数据元素序列按次低位(即十位)的数值依次把各

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 小学教育 > 语文

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1