数据结构课件1-11全书讲第9讲排序幻灯片.ppt

数据结构课件1-11全书讲第9讲排序幻灯片.ppt

  1. 1、本文档共74页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
排序方法的稳定性能 1. 稳定的排序方法指的是,对于两个关键字相等的记录,它们在序列中的相对位置,在排序之前和经过排序之后,没有改变。 2. 当对多关键字的记录序列进行LSD方法排序时,必须采用稳定的排序方法。 排序之前 : { · · · · · Ri(K) · · · · · Rj(K) · · · · · } 排序之后 : { · · · · · Ri(K) Rj(K) · · · · ·· · · · · } 例如: 排序前 ( 56, 34, 47, 23, 66, 18, 82, 47 ) 若排序后得到结果 ( 18, 23, 34, 47, 47, 56, 66, 82 ) 则称该排序方法是稳定的; 若排序后得到结果 ( 18, 23, 34, 47, 47, 56, 66, 82 ) 则称该排序方法是不稳定的。 3. 对于不稳定的排序方法,只要能举出一个实例说明即可。 4. 快速排序、所有选择排序(包括堆排序)和希尔排序是不稳定的排序方法。 例如 : 对 { 4, 3, 4, 2 } 进行快速排序, 得到 { 2, 3, 4, 4 } 外 部 排 序 一. 问题的提出 待排序的记录数量很大,不能一次装入内存,则无法利用前几节 讨论的排序方法 ; 1.按可用内存大小,利用内部排序 方法,构造若干( 记录的) 有序子序列,通常称外存中这些记录有序子序列为 “归并段”; 二、外部排序的基本过程 由相对独立的两个步骤组成: 2.通过“归并”,逐步扩大 (记录的)有序子序列的长度,直至外存中整个记录序列按关键字有序为止。 例如:假设有一个含10,000个记录的磁盘 文件,而当前所用的计算机一次只 能对1000个记录进行内部排序,则 首先利用内部排序的方法得到10个 初始归并段,然后进行逐趟归并。 假设进行2?路归并(即两两归并),则 第一趟由10个归并段得到5个归并段; 最后一趟归并得到整个记录的有序序列。 第三趟由 3 个归并段得到2个归并段; 第二趟由 5 个归并段得到3个归并段; 假设“数据块”的大小为200,即每一次访问外存可以读/写200个记录。 则对于10,000个记录,处理一遍需访问外存100次(读和写各50次)。 分析上述外排过程中访问外存(对外 存进行读/写)的次数: 由此,对上述例子而言, 1)求得10个初始归并段需访问外存100次; 2)每进行一趟归并需访问外存100次; 3)总计访问外存 100 + 4 ? 100 = 500次。 外排总的时间还应包括内部排序 所需时间和逐趟归并时进行内部归并 的时间,显然,除去内部排序的因素 外,外部排序的时间取决于逐趟归并 所需进行的“趟数”。 例如,若对上述例子采用5?路归并, 则只需进行2趟归并,总的访问外存的 次数将压缩到 100 + 2 ? 100 = 300 次。 一般情况下,假设待排记录序列 含 m 个初始归并段,外排时采用 k?路 归并,则归并趟数为 ?logkm?,显然, 随之k的增大归并的趟数将减少,因此 对外排而言,通常采用多路归并。k 的 大小可选,但需综合考虑各种因素。 * template class ElemType void BubbleSort(ElemType elem[], int n) // 操作结果:在数组elem中用起泡排序进行排序 { for (int i = n - 1; i 0; i--) { // 第i趟起泡排序 for (int j = 0; j i; j++) { // 比较elem[j]与elem[j + 1] if (elem[j] elem[j + 1]) { // 如出现逆序,则交换elem[j]和 // elem[j + 1] Swap(elem[j], elem[j + 1]); } } } } 二、一趟快速排序(一次划分)  目标:找一个记录,以它的关键字作为“枢轴”,凡其关键字小于枢轴的记录均移动至该记录之前,反之,凡关键字大于枢轴的记录均移动至该记录之后。 致使一趟排序之后,记录的无序序列R[s..t]将分割成两部分:R[s..i-1]和R[i+1..t],且 R[j]≤ R[i] ≤ R[k] (s≤j≤i-1) 枢轴 (i+1≤k≤t)。 s t low high 设 R[s]=52 为枢轴 将 R[high].k

文档评论(0)

开心农场 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档