10.数据结构概要.ppt

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

第10章 内部排序 10.1 概述 4. 什么叫内部排序?什么叫外部排序? 6. 顺序存储(顺序表)的抽象数据类型如何表示? 7. 内部排序的算法有哪些? 10.2 插入排序 1) 直接插入排序 例2:关键字序列T= (21,25,49,25*,16,08), 请写出直接插入排序的具体实现过程。 2) 折半插入排序 3) 2-路插入排序 基本思想:增设同类型数组d,视为循环向量。以d[1]为中心,原数列中比d[1]小的往前插,比d[1]大的往后插 原数列:49 38 65 97 76 13 27 49 d数组: 4)表插入排序 例:关键字序列 T=(21,25,49,25*,16,08), 请写出表插入排序的具体实现过程。 表插入排序的算法 表插入排序算法分析: 5)希尔(shell)排序(又称缩小增量排序) 例:关键字序列 T=(49,38,65,97,76,13,27,49*,55,04),请写出希尔排序的具体实现过程。 时间效率: 希尔排序算法(其中某一趟的排序操作) 附:希尔排序算法分析 10.3 快速排序(交换排序) 1) 冒泡排序 冒泡排序的算法分析 2) 快速排序 例1:关键字序列 T=(21,25,49,25*,16,08),请写出快速排序的算法步骤。 1.这种不断划分子表的过程,计算机如何自动实现? 例2:关键字序列 T=(21,25,49,25*,16,08),请写出快速排序算法的一趟实现过程。 一趟快速排序算法流程图 整个快速排序的递归算法: 例3:以关键字序列(256,301,751,129,937,863,742,694,076,438)为例,写出执行快速算法的各趟排序结束时,关键字序列的状态。 快速排序算法详细分析: 讨论2. “快速排序”是否真的比任何排序算法都快? 10.4 选择排序 1)简单选择排序 例:关键字序列T= (21,25,49,25*,16,08),请给出简单选择排序的具体实现过程。 简单选择排序的算法如下: 2) 锦标赛排序 (又称树形选择排序) 第一趟: 第二趟: 第三趟: 第四趟: 第五趟: 第六趟: 第七趟: 算法分析: 3) 堆排序 例: 堆排序 基本思想: 以初始关键字序列,建立堆; 输出堆顶最小元素; 调整余下的元素,使其成为一个新堆; 重复2,3步,直到n个元素输出,得到 一个有序序列。 关键问题: 如何由一个无序序列建成一个堆? 如何调整余下的元素成为一个新堆? 堆调整过程 堆调整过程(筛选过程) void HeapAdjust (SqList R[], int s, int m) { //已知R[s..m]中记录的关键字除R[s].key之外均满足堆的定义,本函数调整R[s] 的关键字,使R[s..m]成为一个大顶堆 rc = R[s]; for ( j=2*s; j=m; j*=2 ) { // 沿key较大的孩子结点向下筛选 if ( jm R[j].keyR[j+1].key ) ++j; // j为key较大 //的记录的下标 if ( rc.key = R[j].key ) break; // rc应插入在位置s上 R[s] = R[j]; s = j; } R[s] = rc; // 插入 } // HeapAdjust 例:对刚才建好的大根堆进行排序: 2建堆过程 无序序列建堆过程 方法:从完全二叉树的最后一个非叶结点 ? n/2 ? 开始,反复调用筛选过程,直到第一个结点,则得到一个堆。 建堆算法 附2: 算法流程 堆排序算法分析: 10.5 归并排序 两个有序表合并问题 LA=(3,5,8,9) LB=(2,6,8,9,11,15,20) 则LC=(2,3,5,6,8,8,9,11,11,15,20) 一趟归并排序算法: (两路有序并为一路) 参见教材P283 递归形式的两路归并排序算法: 参见教材P284 (一路无序变为有序) 归并排序算法分析: 10.6 基数排序 (Radix Sort) 1. 什么是“多关键字”排序?实现方法? 多关键字排序的实现方法通常有两种: 2. 单逻辑关键字怎样“按位值”排序? 讨论:是借用MSD方式来排序呢,还是借用LSD方式? 计算机怎样实现LSD算法? 这种LSD排序方

文档评论(0)

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

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

1亿VIP精品文档

相关文档