数据结构与算法:ch10_排序.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文档。上传文档
查看更多
第十章 排序 10.1概述 一、排序 (Sorting) 定义——将一个数据元素(或记录)的任意序列,重新排列成一个按关键字有序的序列叫~ 假设含n个记录的序列为 {R1, R2, …, Rn}, 其相应的关键字序列为 {K1, K2, …, Kn}, 需确定 1, 2, …, n 的一种排列 p1, p2, …, pn ,使其相应的关键字满足如下的非递减(或非递增)关系 K p1 ≤K p2 ≤…≤K pn , 即使序列 {R1, R2, …, Rn} 成为一个按关键字有序的序列 {R p1, R p2, …, R pn} ,这样一种操作称为排序。 假设Ki=Kj (1≤i ≤n, 1 ≤j ≤n, i≠j),且在排序前的序列中Ri领先于Rj (即i﹤j)。若在排序后的序列中Ri仍领先于Rj ,则称所用的排序方法是稳定的;反之,若能使排序后的序列中Rj领先于Ri ,则称所用的排序方法是不稳定的。 二、排序的分类 按待排序记录所在位置进行分类 内部排序:待排序记录存放在内存中进行的排序过程 外部排序:排序过程中尚需对外存进行访问的排序过程 按排序依据的不同原则对内部排序进行分类 插入排序:直接插入排序、折半插入排序、希尔排序 交换排序:冒泡排序、快速排序 选择排序:简单选择排序、堆排序 归并排序:2-路归并排序 基数排序: 按排序依据的工作量不同对内部排序进行分类 简单的排序方法 T=O(n2) 先进的排序方法 T=O(nlogn) 基数排序 T=O(d.n) 三、排序基本操作 比较两个关键字大小 将记录从一个位置移动到另一个位置 10.2 插入排序 10.2.1直接插入排序 (Straight Insertion Sort) 基本思想:是将一个记录插入到已排好序的有序表中,从而得到一个新的、记录数增1的有序表。 一、排序过程: 整个排序过程为n-1趟插入,即先将序列中第1个记录看成是一个有序子序列,然后从第2个记录起逐个进行插入,直至整个序列变成按关键字非递减有序序列为止。 二、算法描述:算法10.1 10.2.3 希尔排序 (Shell’s Sort) ——缩小增量排序 基本思想:先将整个待排记录序列分割成若干子序列分别进行直接插入排序,待整个序列中的记录“基本有序”时,再对全体记录进行一次直接插入排序。 一、排序过程: 先取一个正整数d1n,把所有相隔d1的记录放一组,组内进行直接插入排序;然后取d2d1,重复上述分组和排序操作;直至di=1,即所有记录放进一个组中排序为止。 二、算法描述:算法10.4 , 10.5 10.3 交换排序 一、冒泡排序 (Bubble Sort) (一)排序过程: 首先将第一个记录的关键字与第二个记录的关键字进行比较,若为逆序(r[1].keyr[2].key) ,则交换两个记录,然后比较第二个记录与第三个记录的关键字。依次类推,直至第n-1个记录和第n个记录的关键字比较过为止——上述过程称为第一趟冒泡排序,结果关键字最大的记录被安置在最后一个记录的位置上。 然后对前n-1个记录进行第二趟冒泡排序,结果使关键字次大的记录被安置在第n-1个记录的位置上。 重复上述过程,直到“在一趟排序过程中没有进行过交换记录的操作”为止。 (二)算法描述: 二、快速排序(Quick Sort)—— 霍尔排序 基本思想: 通过一趟排序,将待排序记录分割成独立的两部分,其中一部分记录的关键字均比另一部分记录的关键字小,则可分别对这两部分记录进行排序,以达到整个序列有序。 (一)排序过程: 对r[s, s+1, ……, t]中记录进行一趟快速排序,附设两个指针low和high,设枢轴记录rp=r[s],x=rp.key 初始时令low =s , high=t 首先从 high 所指位置向前搜索,找到第一个关键字小于 x 的记录,并和枢轴记录rp 交换 然后从low 所指位置起向后搜索,找到第一个关键字大于x的记录,并和枢轴记录rp交换 重复上述两步,直至low=high为止 再分别对两个子序列进行快速排序,直到每个子序列只含有一个记录为止 10.4 选择排序 (Selection Sort) 基本思想: 每一趟在n-i+1(i=1,2, …,n-1)个记录中选取关键字最小的记录作为有序序列中第i个记录。 10.4 .1 简单/直接选择排序 (Simple/Straight Selection Sort) 一、排序过程 首先通过n-1次关键字比较,从n个记录中找出关键字最小的记录,将它与第一个记录交换 再通过n-2次关键字比较,从剩余的n-1个记录中找出关键字次小的记录,将它与第二个记录

文档评论(0)

学习让人进步 + 关注
实名认证
文档贡献者

活到老,学到老!知识无价!

1亿VIP精品文档

相关文档