- 1、本文档共102页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构chap009
第十章 内部排序 提要 10.1 概 述 一、什么是排序? 二、内部排序和外部排序 三、内部排序的方法 基于不同的“扩大” 有序序列长度的方法,内部排序方法大致可分下列几种类型: 待排记录的数据类型定义如下: 1. 插入类 2. 交换类 3. 选择类 4. 归并类 10. 2 插 入 排 序 一趟直接插入排序的基本思想: 实现“一趟插入排序”可分三步进行: 不同的具体实现方法导致不同的算法描述 一、直接插入排序 从R[i-1]起向前进行顺序查找, 监视哨设置在R[0]; 对于在查找过程中找到的那些关键字不小于R[i].key的记录,在查找的同时实现记录向后移动; 令 i = 2,3,…, n, 实现整个序列的排序。 算法: 内部排序的时间分析: 对于直接插入排序: 二、折半插入排序 算法: 例如: 三、表插入排序 算法: 如何在排序之后调整记录序列? 四、希尔排序(又称缩小增量排序) 将记录序列分成若干子序列,分别对每个子序列进行插入排序。 例如: 10.3 快 速 排 序 一、起泡排序 时间分析: 二、一趟快速排序(一次划分) 例如 三、快速排序 第一次调用函数 Qsort 时,待排序记录序列的上、下界分别为 1 和 L.length。 四、快速排序的时间分析 最坏情况是待排记录的初始状态为按关键字有序时,快速排序将蜕化为起泡排序,其时间复杂度为O(n2)。 10.4 堆 排 序 一、简单选择排序 简单选择排序的算法描述如下: 时间性能分析 二、堆排序 堆排序即是利用堆的特性对记录序列进行排序的一种排序方法。 定义堆类型为: 所谓“筛选”指的是,对一棵左/右子树均为堆的完全二叉树,“调整”根结点使整个二叉树也成为一个堆。 例如: 建堆是一个从下往上进行“筛选”的过程。 10.5 归 并 排 序 在内部排序中,通常采用的是2-路归并排序。即:将两个位置相邻的记录有序子序列 归并排序的算法 例如: 10.6 基 数 排 序 基数排序是一种借助“多关键字排序”的思想来实现“单关键字排序”的内部排序算法。 一、多关键字的排序 实现多关键字排序通常有两种作法: 例如:学生记录含三个关键字:系别、班号和班内的序列号,其中以系别为最主位关键字。 二、链式基数排序 例如:对下列这组关键字 {209, 386, 768, 185, 247, 606, 230, 834, 539 } 在计算机上实现基数排序时,为减少所需辅助存储空间,应采用链表作存储结构,即链式基数排序,具体作法为: 例如: 基数排序的时间复杂度为O(d(n+rd)) 10.7 各种排序方法的综合比较 一、时间性能 2. 当待排记录序列按关键字顺序有序时 二、空间性能 三、排序方法的稳定性能 例如: 四、关于“排序方法的时间复杂度的下限” 例如:对三个关键字进行排序的判定树如下: 所以,基于“比较关键字”进行排序的排序方法,可能达到的最快的时间复杂度为 O(nlogn)。 本章小结 if ( rc.key = R[j].key ) break; // 再作“根”和“子树根”之间的比较, // 若“=”成立,则说明已找到 rc 的插 // 入位置 s ,不需要继续往下调整 R[s] = R[j]; s = j; // 否则记录上移,尚需继续往下调整 if ( jm R[j].keyR[j+1].key ) ++j; // 左/右“子树根”之间先进行相互比较 // 令 j 指示关键字较大记录的位置 void HeapSort ( HeapType H ) { // 对顺序表 H 进行堆排序 } // HeapSort for ( i=H.length/2; i0; --i ) HeapAdjust ( H.r, i, H.length ); // 建大顶堆 for ( i=H.length; i1; --i ) { H.r[1]←→H.r[i]; // 将堆顶记录和当前未经排序子序列 // H.r[1..i]中最后一个记录相互交换 HeapAdjust(H.r, 1, i-1); // 对 H.r[1] 进行筛选 } 40 55 49 73 81 64 36 12 27 98 例如: 排序之前的关键字序列为 12 36 81 73 49 98 8
您可能关注的文档
- 9光的衍射--黄.doc
- 纤维壁无序程度对低固形物蒸煮的影响.pdf
- 第二章-光的衍射3.doc
- 政府依法行政 公民有序参与.ppt
- 电磁学 电磁介质.pdf
- 光纤通信光开关原理.pdf
- 多铁性材料的第一性原理模型哈密顿量研究.pdf
- 第二章纳米微粒的基本理论.pdf
- 无铅压电陶瓷研究进展.pdf
- 第六章 低能电子衍射.pdf
- CNAS-CL63-2017 司法鉴定-法庭科学机构能力认可准则在声像资料鉴定领域的应用说明.docx
- 12J7-3 河北《内装修-吊顶》.docx
- 12N2 河北省12系列建筑标准设计图集 燃气(油)供热锅炉房工程.docx
- 内蒙古 12S8 排水工程 DBJ03-22-2014.docx
- 山西省 12S10 12系列建筑标准设计 管道支架、吊架.docx
- 16J601-木门窗标准图集.docx
- 12J8 河北省12系列《 楼梯》.docx
- CNAS-GL37 2015 校准和测量能力(CMC)表示指南.docx
- CNAS-RL02-2016 能力验证规则.docx
- 津02SJ601 PVC塑料门窗标准.docx
最近下载
- 2024年广州市高三二模(普通高中毕业班综合测试(二)数学试卷(含官方答案及逐题解析).pdf
- 武汉市2025届高中毕业生四月调研考试(四调)数学试卷(含答案详解).pdf
- (毕业论文)果树采摘机器人的发展现状及运动学分析.doc VIP
- 【高中语文】双新背景下的语文教学设计+85.pptx VIP
- 雨课堂学堂在线《兵棋(中国人民武装警察部队警官学院)》学堂云单元测试考核答案.pdf VIP
- 11.3 一元一次不等式组(教学设计)七年级数学下册(人教版2024).docx
- 年产1万吨一氯甲烷的工艺流程设计.doc
- 医疗器械质量管理制度-全套规章制度.docx VIP
- 木材质量v验收标准.doc
- 直肠癌(外科学课件).ppt VIP
文档评论(0)