- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
滨州学院计算机科学技术系 第三趟结果 第四趟希尔排序,设增量 d = 1 9 11 12 16 23 18 25 31 30 47 36 9 11 12 16 18 23 25 30 31 36 47 滨州学院计算机科学技术系 void ShellInsert ( int L[], int n ) { dk=n/2; while(dk=1){ for ( i=dk+1; i=n; ++i ) { if ( L[i] L[i-dk]) { L[0] = L[i]; // 暂存在R[0] for (j=i-dk; j0(L[0]L[j]); j-=dk) L[j+dk] = L[j]; // 记录后移,查找插入位置 L[j+dk] = L[0]; // 插入 } // if }//for dk/=2; }//while } // ShellInsert 滨州学院计算机科学技术系 开始时d的值较大,子序列中的对象较少,排序速度较快; 随着排序进展,d值逐渐变小,子序列中对象个数逐渐变多,由于前面工作的基础,大多数对象已基本有序,所以排序速度仍然很快。 数据结构 系内数据结构学习网站:00:8080/ds 滨州学院计算机科学技术系 第十章 排序 插入排序 滨州学院计算机科学技术系 本讲内容 排序的相关概念及术语 插入排序 直接插入排序 折半插入排序 希尔排序 滨州学院计算机科学技术系 排序的相关概念及术语 排序是计算机内经常进行的一种操作,其目的是将一组“无序”的记录序列调整为“有序”的记录序列。 滨州学院计算机科学技术系 一般情况下, 假设含n个记录的序列为{ R1, R2, …, Rn } 其相应的关键字序列为 { K1, K2, …,Kn } 这些关键字相互之间可以进行比较,即在 它们之间存在着这样一个关系 : Kp1≤Kp2≤…≤Kpn 按此固有关系将上式记录序列重新排列为 { Rp1, Rp2, …,Rpn }的操作称作排序。 排序的相关概念及术语 滨州学院计算机科学技术系 数据表(datalist): 它是待排序数据对象的有限集合。 关键字(key): 通常数据对象有多个属性域,即多个数据成员组成,其中有一个属性域可用来区分对象,作为排序依据。该域即为关键字。每个数据表用哪个属性域作为关键字,要视具体的应用需要而定。即使是同一个表,在解决不同问题的场合也可能取不同的域做关键字。 排序的相关概念及术语 滨州学院计算机科学技术系 主关键字: 如果在数据表中各个对象的关键字互不相同,这种关键码即主关键字。按照主关键字进行排序,排序的结果是唯一的。 次关键字: 数据表中有些对象的关键字可能相同,这种关键字称为次关键字。按照次关键字进行排序,排序的结果可能不唯一。 排序算法的稳定性: 如果在对象序列中有两个对象r[i]和r[j],它们的关键字 k[i] == k[j],且在排序之前,对象r[i]排在r[j]前面。如果在排序之后,对象r[i]仍在对象r[j]的前面,则称这个排序方法是稳定的,否则称这个排序方法是不稳定的。 滨州学院计算机科学技术系 若整个排序过程不需要访问外存便能完成,则称此类排序问题为内部排序; 反之,若参加排序的记录数量很大,整个序列的排序过程不可能在内存中完成,则称此类排序问题为外部排序。 排序的相关概念及术语 滨州学院计算机科学技术系 内部排序的方法 内部排序的过程是一个逐步扩大 记录的有序序列长度的过程。 经过一趟排序 有序序列区 无 序 序 列 区 有序序列区 无 序 序 列 区 滨州学院计算机科学技术系 基于不同的“扩大” 有序序列长度的方法,内部排序方法大致可分下列几种类型: 插入类 交换类 选择类 归并类 其它方法 滨州学院计算机科学技术系 排序过程中需进行的操作 比较关键字大小 移动记录 排序原则:尽量避免移动操作 滨州学院计算机科学技术系 有序序列R[1..i-1] R[i] 无序序列 R[i..n] 一趟直接插入排序的基本思想: 有序序列R[1..i] 无序序列 R[i+1..n] 2. 插入排序 滨州学院计算机科学技术系 实现“一趟插入排序”可分三步进行: 3.将R[i] 插入(复制)到R[j+1]的位置上。 2.将R[j+1..i-1]中的所有记录均后移 一个位置; 1.在R[1..i-1]中查找R[i]
您可能关注的文档
最近下载
- Unit 1 I love sports Part 1 (课件)2025-2026学年度外研版(三起)英语四年级上册.pptx VIP
- 高血压指南最新版2025完整版原文.docx VIP
- 四川开放大学《演讲与口才》终结性考核-95分.doc VIP
- HACCP过敏原控制程序.pdf VIP
- 浙江省温州市乐成寄宿中学2022-2023学年高一上学期语文期初月考试卷(含答案).docx VIP
- QBT 2623.4-2003 肥皂试验方法 肥皂中水分和挥发物含量的测定 烘箱法.docx VIP
- 地理信息安全在线培训考试题目完整版答案.docx
- 新代说明书.doc VIP
- 水泥混凝土路面“白改黑”施工工艺.pdf VIP
- 中考语文名著导读《红星照耀中国》专项练习题(含答案)1.doc VIP
文档评论(0)