09级第10章排序B.ppt

  1. 1、本文档共41页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
09级第10章排序B,奇迹暖暖公主级第二章,奇迹暖暖公主级第一章,奇迹暖暖公主级第三章,奇迹暖暖少女级第四章,奇迹暖暖少女级第三章,奇迹暖暖公主级第四章,七年级下册数学第八章,七年级下册数学第九章,奇迹暖暖少女级第五章

第10章 内部排序 课堂练习(2002级期末考试题): 建堆算法 (即堆排序算法中的第一步) 3. 怎样堆排序 例:对刚才建好的大根堆进行排序: 堆排序的算法实现 针对结点 i 的堆调整函数HeapAdjust 详介如下: 3. 怎样进行整个序列的堆排序? 堆排序算法分析: 课堂练习(2002级期末考试题) : 10.5 归并排序 一趟归并排序算法: (两路有序并为一路) 参见教材P283 递归形式的两路归并完整排序算法: 参见教材P284 归并排序算法分析: 10.6 基数排序 (Radix Sort) 讨论:是借用MSD方式来排序好呢,还是借用LSD方式? 计算机怎样实现LSD算法? 这种LSD排序方法称为: 讨论:所用队列是顺序结构,浪费空间,能否改用链式结构? 例: 第一趟收集的结果: 第二趟收集的结果: 基数排序算法如何编程实现? 一趟“分配”过程的算法流程 链表基数排序的详细算法: 基数排序算法分析 各种内部排序方法的比较 (教材P289) 0 1 2 3 4 5 6 7 8 9 再次入队 再次出队 再对高位扫描 小结:排序时经过了反复的“分配”和“收集”过程。当对关键字所有的位进行扫描排序后,整个序列便从无序变为有序了。 77 55 64 54 02 11 21 70 1 2 3 4 5 6 7 8 出队后序列 70 64 54 21 11 02 再次分配 再次收集 77 70 64 55 54 21 11 02 再次出队后序列 基数排序 ,77 ,55 用链队列来实现基数排序— 链式基数排序 实现思路: 针对 d 元组中的每一位分量,把原始链表中的所有记录, 按Kij的取值,让 j = d, d-1, …, 1, ① 先“分配”到radix个链队列中去; ② 然后再按各链队列的顺序,依次把记录从链队列中“收集”起来; ③ 分别用这种“分配”、“收集”的运算逐趟进行排序; ④ 在最后一趟“分配”、“收集” 完成后,所有记录就按其关键码的值从小到大排好序了。 能! 请实现以下关键字序列的链式基数排序: T=(614,738,921,485,637, 101,215,530,790,306) 614 921 485 637 738 101 215 530 790 306 第一趟分配 e[0] e[1] e[2] e[3] e[4] e[5] e[6] e[7] e[8] e[9] 614 738 921 485 637 101 215 530 790 306 f[0] f[1] f[2] f[3] f[4] f[5] f[6] f[7] f[8] f[9] 原始序列静态链表: r[0]→ (从最低位 i = 3开始排序,f[ ] 是队首指针,e[ ] 为队尾指针) 第一趟收集(让队尾指针e[i] 链接到下一非空队首指针f[i+1 ] 即可) 530 790 921 101 614 485 215 306 637 738 r[0]→ e[0] e[1] e[2] e[3] e[4] e[5] e[6] e[7] e[8] e[9] 614 738 921 485 637 101 215 530 790 306 f[0] f[1] f[2] f[3] f[4] f[5] f[6] f[7] f[8] f[9] 第二趟分配(按次低位 i = 2 ) 530 790 921 101 614 485 215 306 637 738 第二趟收集(让队尾指针e[i] 链接到下一非空队首指针f[i+1 ] ) 530 790 921 101 614 485 215 306 637 738 r[0]→ r[0]→ 530 790 921 101 614 485 215 306 637 738 e[0] e[1] e[2] e[3] e[4] e[5] e[6] e[7] e[8] e[9] 614 738 921 485 637 101 215 530 790 306 f[0] f[1] f[2] f[3] f[4] f[5] f[6] f[7] f[8] f[9] 第三趟分配(按最高位 i =

文档评论(0)

mydoc + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档