- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
第九章内部排序
概述排序(sorting)将一个数据元素的任意序列,重新排列成一个按关键字有序的序列。数据表(datalist)它是待排序数据对象的有限集合。关键字(key)数据对象有多个属性域,即多个数据成员组成,其中有一个属性域可用来区分对象,作为排序依据,称为关键字。也称为排序码。
排序方法的稳定性假设在对象序列中有两个对象r[i]和r[j],它们的排序码k[i]==k[j],且在排序之前,对象r[i]排在r[j]前面。如果在排序之后,对象r[i]仍在对象r[j]的前面,则称这个排序方法是稳定的,否则称这个排序方法是不稳定的。如:待排序列:49,38,65,97,76,13,27,49(稳定)排序得到的序列: 13,27,38,49,49,65,76,97
内排序与外排序内排序是指在排序期间数据对象全部存放在内存的排序;外排序是指在排序期间全部对象个数太多,不能同时存放在内存,必须根据排序过程的要求,不断在内、外存之间移动的排序。排序的时间开销排序的时间开销是衡量算法好坏的最重要的标志。排序的时间开销可用算法执行中的数据比较次数与数据移动次数来衡量。
内排序分类依不同原则分插入排序、交换排序、选择排序、归并排序、和基数排序等。依所须工作量分简单排序---时间复杂度O(n2)先进排序方法---时间复杂度O(nlog2n)基数排序---时间复杂度O(d·n)
直接插入排序过程0123456i=1i=201234562108254925*162125084925*162125084925*162125084925*162125084925*16i=32125084925*1625*2125084925*16排序前排序后
i=4i=52125084925*1616162125084925*162125084925*162125084925*16080123456
直接插入排序的算法voidInsertSort(SqListL){//按非递减顺序对表进行排序,从后向前顺序比较for(i=2;i=L.length;++i) ifLT(L.r[i].key,L.r[i-1].key){ L.r[0]=L.r[i]; 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]; }//if}
算法分析设待排序对象个数为n,则该算法的主程序执行n-1趟。排序码比较次数和对象移动次数与对象排序码的初始排列有关。直接插入排序的时间复杂度为O(n2)。直接插入排序是一种稳定的排序方法。
折半插入排序(BinaryInsertsort)既然每个要插入记录之前的纪录已经按关键字有序排列,在查找插入位置时就没有必要逐个关键字比较,可以使用折半查找来实现。由此进行的插入排序称之为折半插入排序。
折半插入排序的算法voidBInsertSort(SqListL){ for(i=2;i=L.length;++i){ L.r[0]=L.r[i]; low=1;high=i-1;//查找范围由1到i-1 while(low=high){ m=(low+high)/2; ifLT(L.r[0].key,L.r[m].key)high=m-1; elselow=m+1; }//while折半查找 for(j=i-1;j=high+1;--j)L.r[j+1]=L.r[j]; //折半查找结束后high+1位置即为插入位置 L.r[high+1]=L.r[0]; }//for}//BInsertSort
折半插入排序0123456i=1i=2012345652133i=35521532144i=4215388i=52153161684421384516
算法分析折半搜索比顺序搜索查找快,所
您可能关注的文档
- 石卡公路冬季施工技术交底.doc
- 轻质陶瓷薄板施工技术交底设计.doc
- 鱼池石料平台施工安全技术交底.doc
- 老石台阶施工技术交底设计.doc
- 饵料生物-ntou-aquaticanimalcenter-水生动物-饵料生物.ppt
- 腰疼气滞血瘀的护理措施.doc
- 放射科医师看图象、写报告方法浅谈.ppt
- 铝矾土路面施工技术交底.doc
- 1面诊学基础及面诊步骤.ppt
- 宝宝黄疸时的护理措施.doc
- 从社会心理视角看“内卷”话语的流行机制与情绪传染.pdf
- 机械行业年度报告:科技自强、出海深化.docx
- 基础化工行业深度:3D打印,解锁高端制造的“万能钥匙”.docx
- 公用事业行业深度跟踪:风光贡献全部发电增量,关注板块低配高股息.docx
- 江天科技(920121)新股报告:深耕标签印刷行业,聚焦中高端消费品领域.docx
- 德国《联邦教育规划》中的终身学习体系建设——基于2019年国家级战略文本.pdf
- 计算机行业2026年投资策略:液冷行业未来发展可期.docx
- 技术硬件与设备行业卫星系列报告之二:火箭增效,卫星加速.docx
- 德国“移民子女教育”中的语言支持政策——基于《融合法》第43条语言课程.pdf
- 教育行业26年投资策略:海外教育,景气与困境反转交织,投资机会纷呈.docx
最近下载
- 统编小学语文五年级下册作业设计(全册).doc VIP
- 建筑工程图集 07CJ03-1:轻钢龙骨石膏板隔墙、吊顶(参考图集).pdf VIP
- 基于后悔理论和三支决策理论的智能通道匹配系统及方法.pdf VIP
- 驻场服务人员管理办法.docx VIP
- 一年级上册语文数学无纸笔测试精品课件.pptx VIP
- 煤矿井下机电设备完好性要求(KA25—2025).docx
- 金蝶云星空 V9.0_产品培训_财务_总账.pptx VIP
- 【倍福BECKHOFF】手册:TwinCAT 2 PLC入门教程V2.42.pdf VIP
- 电子教案《交往与合作》第二单元第四课组建自己小团队1.docx VIP
- 轨道交通供电系统故障诊断技术.pptx
原创力文档


文档评论(0)