数据结构DataStructures第十章排序胡学钢张晶计算机与信教程.ppt

数据结构DataStructures第十章排序胡学钢张晶计算机与信教程.ppt

  1. 1、本文档共51页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第十章 排序(sorting) 第十章 排 序 10.1 概述 10.2 插入排序 10.3 交换排序 10.4 选择排序 10.5 归并排序 10.6 多关键字排序与基数排序 10.1 概述 排序——将数据表(a1,a2,……,an)调整为按关键字从小(大)到大(小)排列的过程。 几个术语—— 增排序 减排序 单关键字/多关键字 稳定排序: 排序过程中关键字相同的元素的相对次序不变。 不稳定排序: 排序过程中关键字相同的元素的相对次序发生变化。 内部排序:所有数据在内存 外部排序:部分数据在内存,部分数据在外存(涉及到内外存的交换) 10.1 概述 基本方法: 插入方法 交换方法 选择方法 归并方法 基数方法 评价指标: 时间:比较/移动/交换元素的次数 空间:辅助空间 10.2 插入排序 直接插入排序 希尔排序 10.2 插入排序 — 直接插入排序 基本思想: 将待排序表看作左右两部分, 其中左边为有序区, 右边为无序区, 整个排序过程就是将右边无序区中的元素逐个插入到左边的有序区中,以构成新的有序区。 10.2 插入排序 — 直接插入排序实例 用直接插入排序算法对数据表A=(12,5,4,9,5)从小到大进行排序。 10.2 插入排序 — 直接插入排序算法(1) 算法流程图 10.2 插入排序 — 直接插入排序算法(2) 10.2 插入排序 — 直接插入排序算法分析 稳定性: 稳定排序。 空间性能: 需要一个记录的辅助存储空间 。 时间性能: 与数据表初始状态有关 最好(有序) 最坏(逆序) 平均 比较: n-1 (n+2)(n-1)/2 O(n2) 移动: 2(n-1) (n+4)(n-1)/2 因而适用于基本有序,规模小的数据 思考:能不能在进行一次插入过程中保证至少有一个元素停留在最终的位置上呢? 10.2 插入排序 — 希尔排序 基本思想: 将待排序列划分为若干组,在每组内进行直接插入排序,以使整个序列基本有序,然后再对整个序列进行直接插入排序。 分组方法: 对给定的一个步长d(d0),将下标相差为d的倍数的元素分在一组。 d的取值依次为: d1=n/2, d2=d1/2, ……,dk=1 10.2 插入排序 — 希尔排序实例 10.2 插入排序 — 希尔排序算法及分析 void shell_sort(elementtype A[]){ d=n/2; while(d0) { for(i=d+1;i=n;i++) { x=A[i];j=i-d; while(j0x.keyA[j].key ){ A[j+d].key=A[j].key; j=j-d; } A[j+d]=x; } d=d/2; } } 10.3 交换排序 冒泡排序 快速排序 10.3 交换排序 — 冒泡排序 基本思想: 从一端开始,逐个比较相邻的两个元素,发现倒序即交换。 这里按从后往前(从下往上)逐个比较相邻元素。 10.3 交换排序 — 冒泡排序实例 用冒泡排序算法对数据表A=(12,5,4,9,5)从小到大进行排序。 10.3 交换排序 — 冒泡排序算法 简单算法:void bubble_sort(elementtype A[ ],int n){ for (i=1; i=n-1; i++ )  for (j=n; j=i+1;j-- ) if (A[j].keyA[j-1].key) A[j]==A[j-1]; } 10.3 交换排序 — 冒泡排序算法 10.3 交换排序 — 冒泡排序算法分析 时间复杂度:受数据表初始状态影响 正序 比较元素的次

文档评论(0)

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

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

1亿VIP精品文档

相关文档