- 1、本文档共47页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
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(d=1) { //通过步长控制排序的执行过程 for(i=d+1;i=n;i++) {// 依次插入元素A[i]到本组前面的有序子表中 x=A[i];j=i-d; //j指向当前空位置的同一组的前一个位置 while(j0x.keyA[j].key ){ A[j+d].key=A[j].key; j=j-d; //往后移动元素,腾出前面的空位 } A[j+d]=x; // 插入 } d=d/2; } } 稳定性:不稳定。例:6,3,1,3,9,4 空间性能:1个辅助空间。 时间性能: 与数据表初始状态关系不大: 需要循环log2n趟,每趟O(n) 因而时间复杂度为O(nlog2n) 10.3 交换排序 交换排序基本思想:两两比较待排序元 素,发现倒序即交换。 冒泡排序 快速排序 10.3 交换排序 — 冒泡排序 基本思想: 从一端开始,逐个比较相邻的两个元素,发现倒序即交换。 这里按从后往前(从下往上)逐个比较相邻元素。 10.3 交换排序 — 冒泡排序实例 用冒泡排序算法对数据表A=(12,5,4,9,5)从小到大进行排序。 10.3 交换排序 — 冒泡排序算法 简单算法:void bubble_sort(elementtype A[ ],int n){ for (i=1; in; i++ ) for (j=n; j=i+1;j-- ) if (A[j].keyA[j-1].key) A[j]==A[j-1]; } 10.3 交换排序 — 冒泡排序算法分析 改进的算法的时间复杂度:受数据表初始状态影响 正序 比较元素的次数为n-1次,而交换次数为0 O (n) 逆序 比较和交换次数为n(n-1)/2 P203 O (n2) 一般
您可能关注的文档
- 数据提供和指标说明.doc
- 数据操作,DML,Data Management Language详解.docx
- 数据支撑、高效服务.ppt
- 数据收集培训_CN_v1.2.ppt
- 数据收集与整理多种方法.ppt
- 数据校验手册.docx
- 数据核查变更维护工作操作流程.ppt
- 数据流程图+IPO结构化语言.pptx
- 数据流程图和业务流程图案例.doc
- 数据添加修改.pptx
- 2025年中国铸管沥青漆喷涂机市场调查研究报告.docx
- 2025至2031年中国聚四氟乙割管料行业投资前景及策略咨询研究报告.docx
- 2025至2031年中国屏蔽箱行业投资前景及策略咨询研究报告.docx
- 2025年中国B级电源电涌保护器市场调查研究报告.docx
- 2025至2031年中国陶瓷印章行业投资前景及策略咨询研究报告.docx
- 2025至2031年中国保冷材料行业投资前景及策略咨询研究报告.docx
- 2025至2031年中国金彩立雕玻璃行业投资前景及策略咨询研究报告.docx
- 2025至2030年中国机箱螺母柱数据监测研究报告.docx
- 2025至2030年中国小GS管装饰头数据监测研究报告.docx
- 2025至2030年中国气动电阻焊机数据监测研究报告.docx
最近下载
- 《矿山隐蔽致灾因素普查规范》(KAT22.3-2024)解读-金属非金属露天矿山部分.pdf
- 使用抗凝药物护理要点.pptx VIP
- 急性缺血性卒中血管内治疗中国指南2023版解读.pptx
- 農書-陳旉農書校释.pdf
- 企评家_山东东明石化集团有限公司_企业评价指标报告.pdf
- 浙江省嘉兴市六年级上册期末语文试卷 解析及答案.docx VIP
- 2024年中国低空经济报告.pptx
- 部编版语文五年级下册第二单元 古典名著之旅 大单元整体学历案教案 教学设计附作业设计(基于新课标教学评一致性).docx
- 2024年上海杉达学院单招职业技能测试题库(必刷).docx VIP
- 蜜雪冰城品牌合作协议.docx VIP
文档评论(0)