排序38436复习课程.pptVIP

  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文档。上传文档
查看更多
概述 插入排序 交换排序 选择排序 归并排序 基数排序 各种排序方法比较;概 述;内排序与外排序: 内排序是指在排序期间数据对象全部存放在内存的排序;外排序是指在排序期间全部对象个数太多,不能同时存放在内存,必须根据排序过程的要求,不断在内、外存之间移动的排序。 排序的时间开销: 排序的时间开销是衡量算法好坏的最重要的标志。排序的时间开销可用算法执行中的数据比较次数与数据移动次数来衡量。;内排序分类;排序方法的稳定性: 如果在对象序列中有两 个对象r[i]和r[j], 它们的排序码 k[i] == k[j] , 且在排序之前, 对象r[i]排在r[j]前面。如果在排序之后, 对象r[i]仍在对象r[j]的前面, 则称这个排序方法是稳定的, 否则称这个排序方法是不稳定的。 如待排序列:49,38,65,97,76,13,27,49 使用直接插入排序得到的序列: 13,27,38, 49,49,65,76,97 使用选择法排序得到的序列: 13,27,38, 49, 49,65,76,97 ;一 插入排序;该算法适合于n 较小的情况,时间复杂度为O(n2).;;;*;*;*;*;直接插入排序的算法 void InsertSort ( SqList L ) { //按非递减顺序对表进行排序,从后向前顺序比较 for ( i = 2; i = L.length; ++ i) { L.r[0]=L.r[i]; for ( j = i-1; ( L.r[0] L.r[j] ); - -j ) L.r[j+1]=L.r[j]; L.r[j+1]=L.r[0]; } } ;*;2. 折半插入排序;折半插入排序;3. 2-路插入排序;i = 1;i = 5;基本思想: 当待排记录数n很小时,直接插入排序的效率较高。 当待排序列按关键字基本有序时直接插入排序的效率也较高。 所以从这两点出发可对直接插入排序改进,先将整个待排记录序列分割成为若干子序列分别进行直接插入排序,待整个序列中的记录基本有序时,再对全体记录进行一次直接插入排序。;i = 3;;基本方法设待排序对象序列中的对象个数为n。一般地,第i趟起泡排序从1到n-i+1依次比较相邻两个记录地关键字,如果发生逆序,则交换之,其结果是这n-i+1个记录中,关键字最大的记录被交换到第n-i+1的位置上,最多作n-1趟。;;第 六 趟 排 序 后 ;;*;起泡排序的算法 void BubbleSort ( Sqlist L , int n ) { int i = 1; int flag = 1; while ( i L.length flag ) { flag = 0; //标志置为0,假定未交换 for ( int j = 1; j =L.length- i; j++ ) if ( L.r[ j ] L.r[ j+1] ) { //逆序 Swap ( L.r[j], L.[j+1] ); //交换 flag = 1; //标志置为1,有交换 } i++; } } ;2. 快速排序 (Quick Sort);基准对象则排在这两个子序列中间(这也是该对象最终应安放的位置)。 然后分别对这两个子序列重复施行上述方法,直到所有的对象都排在相应位置上为止。 基准对象也称为枢轴(或支点)记录。;快速排序 (对冒泡排序的改进) 通过一趟排序将待排序列分成两部分,使其中一部分记录的关键字均比另一部分小,再分别对这两部分排序,以达到整个序列有序。 关键字通常取第一个记录的值为基准值。 做法:附设两个指针low和high ,初值分别指向第一个记录和最后一个记录,设关键字为 key ,首先从 high所指位置起向前搜索,找到第一个小于基准值的记录与基准记录交换,然后从low 所指位置起向后搜索,找到第一个大于基准值的记录与基准记录交换,重复这两步直至low=high为止。 时间复杂度:O(log2n) ;*;快速排序过程示意图:;快速排序的过程;快速排序的过程;08;一趟快速排序的具体做法是: 设两个指针low和high,设枢轴记录的关键字为pivotkey,首先从high所指位置起向前搜索找到第一个关键字小于pivotkey的记录和枢轴记录互相交换,然后从low所指位置起向后搜索,找到第一个关键字大于pivotkey的记录和枢轴记录互相交换,重复这两步直至low=high为止。;实际上排序过程中不用每次交换枢轴记录和指针所

文档评论(0)

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

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

1亿VIP精品文档

相关文档