常用排序.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
常用排序

一.插入排序 ????插入排序的基本思想是每步将一个待排序的记录按其排序码值的大小,插到前面已经排好的文件中的适当位置,直到全部插入完为止。插入排序方法主要有直接插入排序和希尔排序。 ①.直接插入排序(稳定) ????接插入排序的过程为:在插入第i个记录时,R1,R2,..Ri-1已经排好序,将第i个记录的排序码Ki依次和R1,R2,..,Ri-1的排序码逐个进行比较,找到适当的位置。使用直接插入排序,对于具有n个记录的文件,要进行n-1趟排序。 代码如下: void?Dir_Insert(int?A[],int?N)??//直接插入排序 { ????int?j,t; ????for(int?i=1;iN;i++) ????{ ????????t=A[i]; ????????j=i-1; ????????while(A[j]t) ????????{ ????????????A[j+1]=A[j]; ????????????j--; ????????} ????????A[j+1]=t; ????} } ②.希尔排序(不稳定): ????希尔(Shell)排序的基本思想是:先取一个小于n的整数d1作为第一个增量把文件的全部记录分成d1个组。所有距离为d1的倍数的记录放在同一个组中。先在各组内进行直接插入排序;然后,取得第二个增量d2d1重复上述的分组和排序,直至所取的增量di=1,即所有记录放在同一组中进行直接插入排序为止。该方法实质上是一种分组插入方法。 ????一般取d1=n/2,di+1=di/2。如果结果为偶数,则加1,保证di为奇数。 ????希尔排序是不稳定的,希尔排序的执行时间依赖于增量序列,其平均时间复杂度为O(n^1.3). 代码如下: void?Shell(int?A[],int?n)??//Shell排序 { ????int?i,j,k,t; ????(n/2)%2?==?0???k?=?n/2+1?:?k?=?n/2;?//保证增量为奇数 ????while(k??0) ????{ ????????for(j=k;jn;?j++) ????????{ ????????????t?=?A[j]; ????????????i?=?j?-?k; ????????????while(i=0??A[i]t) ????????????{ ????????????????A[i+k]=A[i]; ????????????????i=i-k; ????????????} ????????????A[i+k]=t; ????????} ????????if(k?==?1)?break; ????????(k/2)%2?==0???k=k/2+1?:?k=k/2; ????} } 二.选择排序 ????选择排序的基本思想是每步从待排序的记录中选出排序码最小的记录,顺序存放在已排序的记录序列的后面,直到全部排完。选择排序中主要使用直接选择排序和堆排序。 ???? ①.直接选择排序(不稳定) ????直接选择排序的过程是:首先在所有记录中选出序码最小的记录,把它与第1个记录交换,然后在其余的记录内选出排序码最小的记录,与第2个记录交换......依次类推,直到所有记录排完为止。 ????无论文件初始状态如何,在第i趟排序中选出最小关键字的记录,需要做n-i次比较,因此,总的比较次数为n(n-1)/2=O(n^2)。当初始文件为正序时,移动次数为0;文件初态为反序时,每趟排序均要执行交换操作,总的移动次数取最大值3(n-1)。直接选择排序的平均时间复杂度为O(n^2)。直接选择排序是不稳定的。 代码如下: void?Dir_Choose(int?A[],int?n)??//直接选择排序 { ????int?k,t; ????for(int?i=0;in-1;i++) ????{ ????????k=i; ????????for(int?j=i+1;jn;j++) ????????{ ????????????if(A[j]A[k])?k=j; ????????} ????????if(k!=i) ????????{ ????????????t=A[i]; ????????????A[i]=A[k]; ????????????A[k]=t; ????????} ????} } ②.堆排序(不稳定) ????堆排序是一种树形选择排序,是对直接选择排序的有效改进。n个关键字序列 K1,K2,...,Kn称为堆,当且仅当该序列满足(Ki=K2i且Ki=K2i+1)或(Ki=K2i且Ki=K2i+1),(1=i=n/2)。根结点(堆顶)的关键字是堆里所有结点关键字中最小者,称为小根堆;根结点的关键字是堆里所有结点关键

文档评论(0)

jgx3536 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:6111134150000003

1亿VIP精品文档

相关文档