- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
概述插入排序交换排序选择排序归并排序基数排序外排序.ppt
第九章 排序 概述 插入排序 交换排序 选择排序 归并排序 基数排序 外排序 什么是排序 Sorting ? 简单地说,排序就是将一组杂乱无章的数据按一定的规律排列起来。 排序是计算机中经常遇到的操作。 排序的几个基本概念 数据表 Data List 待排序的数据对象的有限集合。 关键码 Key 作为排序依据的数据对象中的属性域。 主关键码 不同的数据对象若关键码互不相同,则这种关键码称为主关键码。 排序的确切定义 使一组任意排列的对象变成一组按关键码线性有序的对象。 排序的几个基本概念 排序算法的稳定性 判断标准:关键码相同的数据对象在排序过程中是否保持前后次序不变。如 2, 2*,1,排序后若为1, 2*, 2 则该排序方法是不稳定的。 内排序与外排序 区分标准:排序过程是否全部在内存进行。 排序的时间开销 它是衡量算法好坏的最重要的标志。通常用算法执行中的数据比较次数和数据移动次数来衡量 静态排序中的数据表的类定义 const int DefaultSize 100; Template class datalist; Template class Element friend calss datalist ; private: Type key; field otherdata; ; public: Type getKey return key; void setKey const Type x key x; Element operator Element x key x- key;otherdata x- otherdata; Type operator Type x return key x- key; Type operator Type x return key x- key; Type operator Type x return key x- key; Type operator Type x return key x- key; template class datalist private: Element *Vector; int MaxSize,CurrentSize; int Partition const int low,const int high public; datalist int MaxSz DefaultSize :MaxSize MaxSz ; void Swap Element x, Element y Element temp x;x y;y temp; void Sort ; 9.2 插入排序 Insert Sorting 基本原理,每步将一个待排序的对象,按其关键码大小,插入到前面已经排好序的一组对象适当位置上,直到对象全部插入为止。 三种常见的插入排序 分类原理,根据往已经排好序的有序数据表中寻找插入位置的方法的不同而区分。 直接插入排序 Insert Sort 折半插入排序 Binary Insert Sort 链表插入排序 希尔排序 Shell Sort 直接插入排序 Insert Sort 基本思想:当插入第i个对象时,前面的V[0],V[1],…,V[i-1]已经排好序,此时,用v[i]的关键码与V[i-1], V[i-2],…的关键码顺序进行比较,找到插入位置即将V[i]插入,原来位置上对象向后顺移。 直接插入排序举例 i 0 1 2 3 4 5 temp [21] 25 49 25* 16 08 25 1 [21 25] 49 25* 16 08 49 2 [21 25 49] 25* 16 08 25* 3 [21 25 25* 49] 16 08 16 4 [16 21 25 25* 49] 08 08 5 [08 16 21 25 25* 49] 直接插入排序程序 Template void dataList ::sort Element temp;int j; for int i 1;i CurrentSize;i++ temp Vector[i];j i; for int j i;j 0;j-- if temp Vector[j-1] Vector[j] Vector[j-1]; else break; Vector[j] temp; 直接插入排序的时间复杂度 考虑关键码的比较次数和对象移动次数, 最好情况时两者分别为n-1与2 n-1 ,最坏情况时两者分别为 KCN 1+2+.
您可能关注的文档
最近下载
- CYX-QEHP-39新改扩建项目环境影响控制程序B0(工厂体系文件模板).doc VIP
- 03~04_项目融资模式之BOT项目.ppt VIP
- 团章考试题及答案.doc VIP
- 2025年中考真题作文解读:此刻,你不一样(威海)(写作指导+例文展示+名师点评).docx
- 小学一年级学习计划..doc VIP
- 包头市户外广告和牌匾设置技术标准标准DB 1502T006—2020.pdf
- 网络直播带货主播能力模型构建研究.docx VIP
- 淮阴工学院班主任工作手册.doc VIP
- 2024年新改版教科版一年级上册科学全册教案教学设计(新教材专用).docx
- 2025道德与法治二年级上册全册核心素养教案教学设计.docx
文档评论(0)