- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
计算机软件及应用数据结构第9章排序 计算机软件及应用数据结构第9章排序 计算机软件及应用数据结构第9章排序 * 第九章 排序 * 概述 插入排序(直接、折半、希尔) 快速排序 交换排序(气泡) 选择排序(直接) 归并排序 第九章 排序 * 排序算法的稳定性: 如果在元素序列中有两 个元素r[i]和r[j], 它们的排序码 k[i] == k[j] , 且在排序之前, 元素r[i]排在r[j]前面。如果在排序之后, 元素r[i]仍在元素r[j]的前面, 则称这个排序方法是稳定的, 否则称这个排序方法是不稳定的。 内排序与外排序: 内排序是指在排序期间数据元素全部存放在内存的排序;外排序是指在排序期间全部元素个数太多,不能同时存放在内存,必须根据排序过程的要求,不断在内、外存之间移动的排序。 * 插入排序 (Insert Sorting) 基本方法是:每步将一个待排序的元素,按其排序码大小,插入到前面已经排好序的一组元素的适当位置上, 直到元素全部插入为止。 基本思想是 : 当插入第i (i≥1) 个元素时,前面的V[0], V[1], …, V[i-1]已经排好序。这时,用V[i]的排序码与V[i-1], V[i-2], …的排序码顺序进行比较,后移,找到插入位置即将V[i]插入。 直接插入排序 (Insert Sort) * 各趟排序结果 21 25 49 25* 16 08 0 1 2 3 4 5 0 1 2 3 4 5 temp 21 25 49 25* 16 08 25 i = 1 0 1 2 3 4 5 temp 21 25 49 25* 16 08 49 i = 2 * 0 1 2 3 4 5 i = 4 i = 5 i = 3 0 1 2 3 4 5 temp 21 25 49 25* 16 08 16 0 1 2 3 4 5 temp 21 25 49 25* 16 08 25* 0 1 2 3 4 5 temp 21 25 49 25* 16 08 08 * 算法分析 设待排序元素个数为currentSize = n, 则该算法的主程序执行n-1趟(第一个元素不用插入)。 排序码比较次数和元素移动次数与元素排序码的初始排列有关。 最好情况下,排序前元素已按排序码从小到大有序,每趟只需与前面有序元素序列的最后一个元素比较1次,总的排序码比较次数为 n-1, 元素移动次数为0。 21 25 49 25* 16 08 0 1 2 3 4 5 * 最坏情况下, 第 i 趟时第 i 个元素必须与前面 i 个元素都做排序码比较, 并且每做1次比较就要做1次数据移动。 21 25 49 28 16 08 0 1 2 3 4 5 * 平均情况下排序的时间复杂度为 o(n2)。 直接插入排序是一种稳定的排序方法。 基本思想是 : 设在顺序表中有一 个元素序列 V[0], V[1], …, V[n-1]。其中, V[0], V[1], …, V[i-1] 是已经排好序的元素。 1)在插入V[i] 时, 利用折半搜索法寻找V[i] 的插入位置。 2)找到位置后,再将插入位置之后的元素向后顺次移动。 3)插入。 折半插入排序 (Binary Insertsort) * 算法分析 折半搜索比顺序搜索快, 所以折半插入排序就 平均性能来说比直接插入排序要快。 它所需的排序码比较次数与待排序元素序列的初始排列无关,仅依赖于元素个数。 折半插入排序是一个稳定的排序方法。 * 希尔排序方法又称为缩小增量排序,基本思想是 : 1)选择一个步长序列d1,d2,…,dk,其中didj (ij), dk=1; 2)按步长序列个数k,对序列进行k趟排序; 3)第I趟排序时, 从第一个关键字开始,将间隔为di的关键字组成一个序列; 从第二个关键字开始,将间隔为di的关键字组成一个序列;
原创力文档


文档评论(0)