- 1、本文档共79页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
* 各种排序方法时间性能 1.平均的时间性能 基数排序 时间复杂度为 O(nlogn): 快速排序、堆排序和归并排序 时间复杂度为 O(n2): 直接插入排序、起泡排序和 简单选择排序 时间复杂度为 O(n): * 2.当待排记录序列按关键字顺序有序时 3.简单选择排序、堆排序和归并排序的时间性能不随记录序列中关键字的分布而改变。 直接插入排序和起泡排序能达到O(n)的时间复杂度, 快速排序的时间性能蜕化为O(n2) 。 各种排序方法时间性能 * 指的是排序过程中所需的辅助空间大小 1.所有的简单排序方法(包括:直接插入、 起泡和简单选择) 和堆排序的空间复杂度为O(1); 2.快速排序为O(logn),为递归程序执行过程中,栈所需的辅助空间; 各种排序方法空间性能 3.归并排序所需辅助空间最多,其空间复杂度为 O(n); 4.链式基数排序需附设队列首尾指针,则空间复杂度为 O(rd)。 * 排序方法的稳定性能 1. 稳定的排序方法指的是,对于两个关键字相等的记录,它们在序列中的相对位置,在排序之前和经过排序之后,没有改变。 2. 当对多关键字的记录序列进行LSD方法排序时,必须采用稳定的排序方法。 排序之前 : { · · · · · Ri(K) · · · · · Rj(K) · · · · · } 排序之后 : { · · · · · Ri(K) Rj(K) · · · · ·· · · · · } 3. 快速排序、堆排序和希尔排序是不稳定的排序方法。 * 例如: 排序前 ( 56, 34, 47, 23, 66, 18, 82, 47 ) 若排序后得到结果 ( 18, 23, 34, 47, 47, 56, 66, 82 ) 则称该排序方法是稳定的; 若排序后得到结果 ( 18, 23, 34, 47, 47, 56, 66, 82 ) 则称该排序方法是不稳定的。 * 排序方法的时间复杂度的下限 本章讨论的各种排序方法,除基数排序外,其它方法都是基于“比较关键字”进行排序的排序方法。 可以证明, 这类排序法可能达到的最快的时间复杂度为O(nlogn)。 (基数排序不是基于“比较关键字”的排序方法,所以它不受这个限制。) * 例如:对三个关键字进行排序的判定树如下: K1K3 K1K2 K1K3 K2K3 K2 K3 K2K1K3 K1K2K3 K3K2K1 K2K3K1 K3K1K2 K1K3K2 1.树上的每一次“比较”都是必要的; 2.树上的叶子结点包含所有可能情况。 * 一般情况下,对n个关键字进行排序,可能得到的结果有n! 种,由于含n! 个叶子结点的二叉树的深度不小于?log2(n!)? +1, 则对 n 个关键字进行排序的比较次数至少是 ?log2(n!)? ? nlog2n (斯蒂林近似公式)。 所以,基于“比较关键字”进行排序的 排序方法,可能达到的最快的时间复杂度为 O(nlogn)。 * 对外存中数据的读/写是以“数据块”为单位进行的; 读/写外存中一个“数据块”的数据所需要的时间为: TI/O = tseek + tla + n? twm 其中 tseek 为寻查时间(查找该数据块所在磁道) tla 为等待(延迟)时间 n? twm 为传输数据块中n个记录的时间。 外部排序 待排序的记录数量很大,不能一次装入内存,则无法利用前面讨论的排序方法 * 1.按可用内存大小,利用内部排序方法,构造若干( 记录的) 有序子序列,通常称外存中这些记录有序子序列为 “归并”; 外部排序的基本过程 由相对独立的两个步骤组成: 2.通过“归并”,逐步扩大 (记录的)有序子序列的长度,直至外存中整个记录序列按关键字有序为止。 * 例如:假设有一个含10,000个记录的磁盘 文件,而当前所用的计算机一次只 能对1000个记录进行内部排序,则 首先利用内部排序的方法得到10个 初始归并段,然后进行逐趟归并。 假设进行2?路归并(即两两归并),则 第一趟由10个归并段得到5个归并段; 最后一趟归并得到整个记录的有序序列。 第三趟由 3 个归并段得到2个归并段; 第二趟由 5 个归并段得到3个归并段; * 假设“数据块”的大小为200,即每一次访问外存可以读/写200个记录。 则对于10,000个记录,处理一遍需访问外存100次(读和写各50次)。 分析上述外排过程中
您可能关注的文档
- 第7章螺纹连接试卷.ppt
- 爱写诗的小螃蟹教程.ppt
- 第八章_线路工程测量试卷.ppt
- 第八章_新闻传播法制的历史发展试卷.ppt
- 爱心树课件教程.ppt
- 第八章_有机高分子试卷.ppt
- 爱心树阅读示例教程.ppt
- 第八章_原根与离散对数试卷.ppt
- 爱眼日保护视力防近视教程.ppt
- 爱婴球囊临床运用教程.ppt
- 2025至2030年中国开信封刀片数据监测研究报告.docx
- 2025至2030年中国开业庆典赠品数据监测研究报告.docx
- 2025至2030年拌馅调料项目投资价值分析报告.docx
- 2025至2030年护罩网格项目投资价值分析报告.docx
- 2025至2030年搅拌输送车进出料项目投资价值分析报告.docx
- 2025年树的哭诉作文.pdf
- 2025至2030年恒温孵化专用温度控制器项目投资价值分析报告.docx
- 2025至2030年中国异径直通管件数据监测研究报告.docx
- 2025至2030年中国异型珠饰刀数据监测研究报告.docx
- 2025至2030年中国平板式耐高温过滤器数据监测研究报告.docx
文档评论(0)