- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构Chap10 内部排序
最高位优先法(MSD):先对最高位关键字k1(如花色)排序,将序列分成若干个子序列,每个子序列有相同的k1值;然后让每个子序列对次关键字k2(如面值)排序,又分成若干更小的子序列;依次重复,直至就每个子序列对最低位关键字kd排序;最后将所有子序列依次连接在一起成为一个有序序列。 最低位优先法(LSD):从最低位关键字kd进行排序,然后再对高一位的关键字排序,…… 依次重复,直至对最高位关键字k1排序后,便成为一个有序序列。 多关键字排序方法 MSD与LSD的不同特点 按MSD排序,必须将序列逐层分割成若干子序列,然后对各子序列分别排序。 按LSD排序,不必分成子序列,对每个关键字都是整个序列参加排序;并且可不通过关键字比较,而通过若干次分配与收集实现排序。 基数排序:借助“分配”和“收集”对单逻辑关键字进行排序的一种方法。 链式基数排序:用链表作存储结构的基数排序。 链式基数排序 设置10个队列,f[i]和e[i]分别为第i个队列的头指针和尾指针。 第一趟分配对最低位关键字(个位)进行,改变记录的指针值,将链表中记录分配至10个链队列中,每个队列记录的关键字的个位相同。 第一趟收集是改变所有非空队列的队尾记录的指针域,令其指向下一个非空队列的队头记录,重新将10个队列链成一个链表。 重复上述两步,进行第二趟、第三趟分配和收集,分别对十位、百位进行,最后得到一个有序序列。 链式基数排序步骤: 例2 初始状态: 278 109 063 930 589 184 505 269 008 083 109 589 269 278 063 930 083 184 505 008 e[0] e[1] e[2] e[3] e[4] e[5] e[6] e[7] e[8] e[9] f[0] f[1] f[2] f[3] f[4] f[5] f[6] f[7] f[8] f[9] 一趟分配 930 063 083 184 505 278 008 109 589 269 一趟收集: 505 008 109 930 063 269 278 083 184 589 二趟收集: 083 184 589 063 505 269 930 e[0] e[1] e[2] e[3] e[4] e[5] e[6] e[7] e[8] e[9] f[0] f[1] f[2] f[3] f[4] f[5] f[6] f[7] f[8] f[9] 二趟分配 008 109 278 930 063 083 184 505 278 008 109 589 269 一趟收集: 008 063 083 109 184 269 278 505 589 930 三趟收集: 109 008 184 930 e[0] e[1] e[2] e[3] e[4] e[5] e[6] e[7] e[8] e[9] f[0] f[1] f[2] f[3] f[4] f[5] f[6] f[7] f[8] f[9] 三趟分配 063 083 269 278 505 589 505 008 109 930 063 269 278 083 184 589 二趟收集: 算法评价 时间复杂度: 分配:T(n)=O(n) 收集:T(n)=O(rd) 总时间复杂度: T(n)=O(d(n+rd)) 其中: n——记录数 d——关键字数 rd——关键字取值范围 空间复杂度:S(n)=2rd个队列指针+n个指针域空间 基数 10.7 各种内部排序方法的比较讨论 直接插入排序、直接选择排序和冒泡排序是三种简单的排序方法,它们的时间复杂度均为O(n2),空间复杂度均为O(1);但由于它们的时间复杂度的系数不同,所以直接插入排序快于直接选择排序,而直接选择排序又快于冒泡排序。 堆排序、快速排序和归并排序是三种较快的排序方法,它们的时间复杂度均为O(nlogn),但平均速度最快的是快速排序;它们的空间复杂度均为O(1)、O(logn)和O(n)。 本章讨论的排序算法多数是在顺序存储结构上实现的,因此在排序过程中需进行大量的记录移动。当n很大时,很耗费时间,此时宜采用静态链表作存储结构。如表插入排序、链式基数排序,以修改指针代替移动记录。 快速排序和堆排序无法实现链式排序。 若Ki=Kj,排序前ij,排序后仍保持ij,此排序属稳定排序。 一般来说,排序过程中的“比较”是在“相邻两个记录关键字”间进行的排序方法是稳定的。 基数排序,以及时间复杂度为O(n2)的简单排序方法是稳定的。 快速排序,堆排序,希尔排序等时间性能较好的排序方法都是不稳定的。 综合题十 作 业 * * void QuickSort
您可能关注的文档
最近下载
- 2025年AI在企业人力资源中的应用白皮书2.0 -智、效双驱: 赋新质、创新生.pdf VIP
- CRL-H户用超声热量表-汇中仪表.pdf VIP
- 第二语言习得02 相关领域与研究传统 PPT课件.pptx VIP
- 人工智能的利与弊最新完整版本.pptx VIP
- CRTAS-2024-05 互联网租赁自行车运营服务规范.docx
- 姑溪河当涂闸枢纽工程环境影响报告书.pdf VIP
- 项目管理人员安全培训课件.pptx VIP
- 【2024版】普通话水平测试用朗读作品 50 篇带拼音版.pdf VIP
- 第二语言习得03 早期研究 PPT课件.pptx VIP
- 汽车行业质量管理体系IATF16949认证审核及评审清单(内审员、外审员、过程审核员如何开展审核?).pdf VIP
原创力文档


文档评论(0)