- 3
- 0
- 约7.52千字
- 约 55页
- 2016-12-17 发布于湖北
- 举报
第九章 排序 主讲:杨同峰 第九章 排序 概述 插入排序 交换排序 选择排序 基数排序 概述 排序:将一组杂乱无章的数据按一定的规律顺次排列起来。 概述 排序码(key): 通常数据元素有多个属性域, 即多个数据成员组成, 其中有一个属性域可用来区分元素, 作为排序依据。该域即为排序码。每个数据表用哪个属性域作为排序码,要视具体的应用需要而定。 排序算法的稳定性: 如果在元素序列中有 2 个元素r[i]和r[j], 它们的排序码 k[i] == k[j] , 且在排序之前, 元素r[i]排在r[j]前面。如果在排序之后, 元素r[i]仍在元素r[j]的前面, 则称这个排序方法是稳定的, 否则称这个排序方法是不稳定的。 内排序: 是指在排序期间数据元素全部存放在内存的排序。 外排序: 是指在排序期间全部元素个数太多,不能同时存放在内存,必须根据排序过程的要求,不断在内、外存之间移动的排序。 排序的时间开销: 排序的时间开销是衡量算法好坏的最重要的标志。排序的时间开销可用算法执行中的数据比较次数与数据移动次数来衡量。 算法运行时间代价的大略估算 一般都按平均情况进行估算。 对于那些受元素排序码序列初始排列及元素个数影响较大的,需要按最好情况和最坏情况进行估算。 基本方法是:设待排序元素序列中的元素个数为 n。最多作 n-1 趟,i = 1, 2, ?, n-1。在第 i 趟中从后向前,j = n-1, n-2, ?, i,顺次两两比较V[j-1].key和V[j].key。如果发生逆序,则交换V[j-1]和V[j]。 算法分析 第i趟对待排序元素序列V[i-1],V[i],?,V[right]进行排序,结果将该序列中排序码最小的元素交换到序列的第一个位置(i-1)。 起泡排序需要一个附加元素以实现元素值的对换。起泡排序是一个稳定的排序方法。 最多做n-1趟起泡就能把所有元素排好序。 在元素的初始排列已经按排序码从小到大排好序时,此算法只执行一趟起泡,做n-1次排序码比较,不移动元素。这是最好的情形。 最坏的情形是算法执行n-1趟起泡,第i趟 (1≤ i?n) 做n-i次排序码比较, 执行n-i次元素交换。在最坏情形下总的排序码比较次数KCN和元素移动次数RMN为: 插入排序 (Insert Sorting) 基本方法是:每步将一个待排序的元素,按其排序码大小,插入到前面已经排好序的一组元素的适当位置上, 直到元素全部插入为止。 直接插入排序 (Insert Sort) 基本思想是 : 当插入第i (i≥1) 个元素时,前面的V[0], V[1], …, V[i-1]已经排好序。这时,用V[i]的排序码与V[i-1], V[i-2], …的排序码顺序进行比较,插入位置即将V[i]插入,原来位置上的元素向后顺移。 算法分析 设待排序元素个数为currentSize = n, 则该算法的主程序执行n-1趟。 排序码比较次数和元素移动次数与元素排序码的初始排列有关。 最好情况下,排序前元素已按排序码从小到大有序,每趟只需与前面有序元素序列的最后一个元素比较1次,总的排序码比较次数为 n-1, 元素移动次数为0。 最坏情况下, 第 i 趟时第 i 个元素必须与前面 i 个元素都做排序码比较, 并且每做1次比较就要做1次数据移动。则总排序码比较次数KCN和元素移动次数RMN分别为 平均情况下排序的时间复杂度为 o(n2)。 直接插入排序是一种稳定的排序方法。 希尔排序 (Shell Sort) 希尔排序方法又称为缩小增量排序。该方法的基本思想是 : 设待排序元素序列有 n 个元素, 首先取一个整数 gap n 作为间隔,将全部元素分为 gap 个子序列,所有距离为 gap 的元素放在同一个子序列中,在每一个子序列中分别 施行直接插入排序。然后缩小间隔 gap, 例如取 gap = ?gap/2?,重复上述的子序列划分和排序工作。直到最后取 gap == 1,将所有元素放在同一个序列中排序为止。 开始时 gap 的值较大,子序列中的元素较少,排序速度较快; 随着排序进展,gap 值逐渐变小, 子序列中元素个数逐渐变多,由于前面工作的基础,大多数元素已基本有序,所以排序速度仍然很快。 算法分析 Gap的取法有多种。最初 shell 提出取 gap = ?n/2?,gap = ?gap/2?,直到gap = 1。knuth 提出取 gap = ?gap/3? +1。还有人提出都取奇数为好,也有人提出各 gap 互质为好。 对特定的待排序元素序列,可以准确地估算排序码的比较次数和元素移动次数。 想要弄清排序码比较次数和元素移动次数与增量选择之间的依赖关系,并给出完整的数学分析,还没有人能够
您可能关注的文档
- 数据库6版讲稿第五章----高级SQL.ppt
- 数据库6版讲稿第六章----形式化关系查询语言.ppt
- 数据传输光缆项目.ppt
- Cowboy Culture(牛仔文化).pptx
- Copy of EHS Annual Trainning 2016.ppt
- 数据库ppt第1章2.ppt
- 数据备份、恢复和报表.ppt
- 数据库原理与应用试卷1.doc
- 数据库原理 实验六 数据库的备份与恢复new.doc
- 数据库基础试题8.doc
- 基于云计算的教学管理信息化平台功能拓展与教学评价改革教学研究课题报告.docx
- 2026年北海康养职业学院单招综合素质考试题库附答案详解.docx
- 2026年宝鸡职业技术学院单招职业技能考试题库带答案详解.docx
- 2026年南京机电职业技术学院单招综合素质考试题库附答案详解.docx
- 2026年哈密职业技术学院单招职业技能测试题库含答案详解.docx
- 2026年信阳职业技术学院单招职业技能考试题库及答案详解1套.docx
- 2026年徽商职业学院单招职业倾向性考试题库参考答案详解.docx
- 2026年信阳职业技术学院单招职业技能测试题库带答案详解.docx
- 2026年呼和浩特职业学院单招职业倾向性测试题库及完整答案详解1套.docx
- 2026年嘉兴职业技术学院单招职业适应性考试题库带答案详解.docx
最近下载
- 第五单元 第三节 可视化分析数据 课件 粤教版(2025)信息科技四年级.pptx VIP
- 契税培训课件.pptx VIP
- 二甲基乙醇胺化学品安全技术说明书MSDS.docx VIP
- 标准图集-22G101-3 混凝土结构施工图平面整体表示方法制图规则和构造详图-独立基础、条形基础、筏形基础、桩基础.pdf VIP
- 《3岁以下婴幼儿生活照护托育服务规范》(DB37T 4784—2024).pdf VIP
- 2025年安徽省中考数学试卷真题含答案.pdf VIP
- T /CNCA 128—2025 露天煤矿土石方剥离综合单价确定方法.pdf VIP
- 2025年南京交通职业技术学院单招英语2014-2024历年真题考点试卷摘选含答案解析.doc
- 人教英语八年级下册单词表默写(2026版).xlsx VIP
- 口述档案的收集与整理-.pdf VIP
原创力文档

文档评论(0)