- 1、本文档共92页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构课程的内容 第9章 内部排序 9.1 概述 4. 什么叫内部排序?什么叫外部排序? 6. 顺序存储(顺序表)的抽象数据类型如何表示? 7. 内部排序的算法有哪些? 9.2 插入排序 1) 直接插入排序 直接插入排序算法 Void InsertSort(SqList L){ for (i=2;i=L.length;++i) { L.r[0]=L.r[i]; //设定监视哨 j=i-1; if (LT(L.r[i].key,L.r[i-1].key)) for (j=i-1;LT(L.r[0].key,L.r[ j ].key);- -j) L.r[j+1]=L.r[j]; //记录后移 L.r[j+1]=L.r[0]; //插入记录 } 例2:关键字序列T= (21,25,49,25*,16,08),请写出直接插入排序的具体实现过程。 直接插入排序的算法分析 2) 折半插入排序 折半插入排序的算法分析 3)表插入排序 例:关键字序列 T=(21,25,49,25*,16,08), 请写出表插入排序的具体实现过程。 表插入排序的算法 表插入排序算法分析: 4)希尔(shell)排序(又称缩小增量排序) 例:关键字序列 T=(49,38,65,97, 76, 13, 27, 49*,55, 04),请写出希尔排序的具体实现过程。 时间效率: 附:希尔排序算法分析 希尔排序算法(其中某一趟的排序操作) 课堂练习: 原始序列: 256,301,751,129,937,863,742,694,076,438 原始序列: 256,301,751,129,937,863,742,694,076,438 9.3 交换排序 1) 冒泡排序 冒泡排序的算法分析 2) 快速排序 例1:关键字序列 T=(21,25,49,25*,16,08),请写出快速排序的算法步骤。 1.这种不断划分子表的过程,计算机如何自动实现? 例2:关键字序列 T=(21,25,49,25*,16,08),请写出快速排序算法的一趟实现过程。 一趟快速排序算法流程图 整个快速排序的递归算法: 例3:以关键字序列(256,301,751,129,937,863,742,694,076,438)为例,写出执行快速算法的各趟排序结束时,关键字序列的状态。 快速排序算法详细分析: 讨论2. “快速排序”是否真的比任何排序算法都快? 9.4 选择排序 1)简单选择排序 例:关键字序列T= (21,25,49,25*,16,08),请给出简单选择排序的具体实现过程。 简单选择排序的算法如下:(亦可参见教材P276) 2) 锦标赛排序 (又称树形选择排序) 第一趟: 第二趟: 第三趟: 第四趟: 第五趟: 第六趟: 第七趟: 算法分析: 3) 堆排序 例: 2. 怎样建堆? 建堆算法 (其实是堆排序算法中的第一步) 针对结点 i 的堆调整函数HeapAdjust如下: 3. 怎样进行堆排序? 例:对刚才建好的大根堆进行排序: 堆排序的算法 附1:基于初始堆进行堆排序的算法步骤: 附2:算法流程 堆排序算法分析: 9.5 归并排序 一趟归并排序算法: (两路有序并为一路) 参见教材P283 递归形式的两路归并排序算法: 参见教材P284 (一路无序变为有序) 归并排序算法分析: 9.6 基数排序 (Radix Sort) 1. 什么是“多关键字”排序?实现方法? 多关键字排序的实现方法通常有两种: 2. 单逻辑关键字怎样“按位值”排序? 讨论:是借用MSD方式来排序呢,还是借用LSD方式? 计算机怎样实现LSD算法? 这种LSD排序方法称为: 讨论:所用队列是顺序结构,浪费空间,能否改用链式结构? 例: 第一趟收集的结果: 第二趟收集的结果: 如何编程实现? 一趟“分配”过程的算法流程 链表基数排序的算法: 基数排序算法分析 各种内部排序方法的比较 (教材P289) 讨论:若初始记录基本无序,则选用哪些排序方法比较适合?若初始记录基本无序,则最好选用哪些排序方法? 08 16 21 25* 25 49 交换 1号与3 号记录 21 16 08 25* 25 49 从 1 号到 3号 重新 调整为最大堆 21 16 25* 08 25 49 1 2 3 4 5 6 08 16 25* 25 21 49 1 3 6 5 4 2 08 16 21 25* 25 49 交换 1 号与2 号记录 16
您可能关注的文档
- 天津医科大学内科学课件 Cardiac Arrhythmias.ppt
- 天津医科大学内科学课件 Chronic Renal.ppt
- 天津医科大学内科学课件 COPD(二).ppt
- 天津医科大学内科学课件 COPD(一).ppt
- 天津医科大学内科学课件 Cor Pulmonale.ppt
- 天津医科大学内科学课件 Coronary Artery Disease.ppt
- 天津医科大学内科学课件 Diabetes Mellitus(二).ppt
- 天津医科大学内科学课件 Diabetes Mellitus(一).ppt
- 天津医科大学内科学课件 Functional Gastrointestinal Disorders.ppt
- 天津医科大学内科学课件 GASTRITIS.ppt
- 2025AACR十大热门靶点推荐和解读报告52页.docx
- 财务部管理报表.xlsx
- 高中物理新人教版选修3-1课件第二章恒定电流第7节闭合电路欧姆定律.ppt
- 第三单元知识梳理(课件)-三年级语文下册单元复习(部编版).pptx
- 俄罗斯知识点训练课件-七年级地理下学期人教版(2024).pptx
- 课外古诗词诵读龟虽寿-八年级语文上学期课内课件(统编版).pptx
- 高三语文二轮复习课件第七部分实用类文本阅读7.2.1.ppt
- 高考物理人教版一轮复习课件第4章第3讲圆周运动.ppt
- 高考英语一轮复习课件53Lifeinthefuture.ppt
- 2025-2030衣柜行业风险投资发展分析及投资融资策略研究报告.docx
最近下载
- 普法知识宣传.pptx VIP
- 人教版(2024)七年级地理上册教学设计全册.pdf VIP
- 2025年根河市“归雁计划”模拟试卷带答案详解(名师推荐).docx VIP
- 水泥性能与检测.ppt VIP
- 记叙文阅读之记叙顺序课件(共31张ppt) 2025年中考语文一轮复习(全国通用).pptx VIP
- 2024年高考物理试卷(甘肃)(空白卷).pdf VIP
- 农村土地永久互换协议合同.docx VIP
- 2025至2030年中国智能胎教仪市场分析及竞争策略研究报告.docx
- 2025党校入党积极分子发展对象考试题库(含答案).docx VIP
- 人教版高中数学选择性必修二全套教材例题课后习题变式及答案解析.pdf VIP
文档评论(0)