Java程序员必知的8大排序(图文示例).docx

Java程序员必知的8大排序(图文示例).docx

ID:55209727

大小:678.07 KB

页数:13页

时间:2020-05-03

Java程序员必知的8大排序(图文示例).docx_第1页
Java程序员必知的8大排序(图文示例).docx_第2页
Java程序员必知的8大排序(图文示例).docx_第3页
Java程序员必知的8大排序(图文示例).docx_第4页
Java程序员必知的8大排序(图文示例).docx_第5页
资源描述:

《Java程序员必知的8大排序(图文示例).docx》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、1、直接插入排序(1)基本思想:在要排序的一组数中,假设前面(n-1)[n>=2]个数已经是排好顺序的,现在要把第n个数插到前面的有序数中,使得这n个数也是排好顺序的。如此反复循环,直到全部排好顺序。(2)实例 (3)用java实现publicclassinsertSort{publicinsertSort(){inta[]={49,38,65,97,76,13,27,49,78,34,12,64,5,4,62,99,98,54,56,17,18,23,34,15,35,25,53,51};inttemp=0;for(inti=1;i

2、=i-1;temp=a[i];for(;j>=0&&temp

3、2)实例:(3)用java实现publicclassshellSort{publicshellSort(){inta[]={1,54,6,3,78,34,12,45,56,100};doubled1=a.length;inttemp=0;while(true){d1=Math.ceil(d1/2);intd=(int)d1;for(intx=0;x=0&&temp

4、d==1)break;}for(inti=0;i

5、=i+1;position=i;inttemp=a[i];for(;j=h2i,hi>=2i+1)或(hi<=h2i,hi<=2i+1)(i=1

6、,2,...,n/2)时称之为堆。在这里只讨论满足前者条件的堆。由堆的定义可以看出,堆顶元素(即第一个元素)必为最大项(大顶堆)。完全二叉树可以很直观地表示堆的结构。堆顶为根,其它为左子树、右子树。初始时把要排序的数的序列看作是一棵顺序存储的二叉树,调整它们的存储序,使之成为一个堆,这时堆的根节点的数最大。然后将根节点与堆的最后一个节点交换。然后对前面(n-1)个数重新调整使之成为堆。依此类推,直到只有两个节点的堆,并对它们作交换,最后得到有n个节点的有序序列。从算法描述来看,堆排序需要两个过程,一是建立堆,二是堆顶与堆的最后一个元素交换位置。所以堆排序有两个函数组成。一

7、是建堆的渗透函数,二是反复调用渗透函数实现排序的函数。(2)实例:初始序列:46,79,56,38,40,84建堆:交换,从堆中踢出最大数依次类推:最后堆中剩余的最后两个结点交换,踢出一个,排序完成。(3)用java实现importjava.util.Arrays;publicclassHeapSort{inta[]={49,38,65,97,76,13,27,49,78,34,12,64,5,4,62,99,98,54,56,17,18,23,34,15,35,25,53,51};publicHeapSort(){heapS

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。