- 1、本文档共41页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
002程序性能3汇编
* * 选择排序性能 最好情况:数组a有序。 最坏情况:数组a最大元素在首位,其他与元素 已经有序。 最好 最坏 比较 n-1 n(n-1)/2 移动 3 3(n-1) * * 2-9冒泡排序的缺点? void Bubble (T a[], int n) { for ( int i = 0; i n-1; i++) if(a[i]a[i+1]) Swap(a[i],a[i+1]); } void BubbleSort (T a[], int n) { for ( int i = n; i1; i- -) Bubble(a,i) ; } 优化冒泡排序 * * 如果在一次冒泡过程中没有发生元素互换,则说明数组已经按序排列,没有必要再继续进行冒泡过程。 优化冒泡排序 * * templateclass T bool Bubble(T a[], int n) { //把a[0:n-1] 中最大元素冒泡至右端 bool swapped = false; // 尚未发生交换 for (int i = 0; i n - 1; i++) if (a[i] a[i+1]) { Swap(a[i], a[i+1]); swapped = true; // 发生了交换 } return swapped; } 程序2-13 及时终止的冒泡排序 * * templateclass T void BubbleSort(T a[], int n) {// 及时终止的冒泡排序 for(int i = n;i1 Bubble(a,i);i- -) ; } 最坏情况下比较次数,移动次数 ? 最好情况下比较次数,移动次数 ? 程序2-13 及时终止的冒泡排序 * * 冒泡排序性能 最好情况:数组a最初已经有序。 最坏情况:数组a倒序。 最好 最坏 比较 n-1 n(n-1)/2 移动 0 3*n(n-1)/2 * * templateclass T void InsertionSort(T a[], int n) { for (int i=1; i n; i++) { //将a[i]插入a [ 0 : i-1 ] T t=a[i]; int j; for (j=i-1;j = 0 ta[j]; j--) a[j+1]=a[j]; a[j+1]=t; }最坏情况下比较次数? 移动次数? } 最好情况下比较次数? 移动次数? 程序2-15 另外一种插入排序 * * 插入排序性能 最好情况:数组a最初已经有序。 最坏情况:数组a倒序。 最好 最坏 比较 n-1 n(n-1)/2 移动 n-1 n-1+n(n-1)/2 * * 排序算法比较 算法 最好 最坏 名次排序 比较 n(n-1)/2+n n(n-1)/2+n 移动 0 6(n-1) 选择排序 比较 n-1 n(n-1)/2 移动 3 3(n-1) 冒泡排序 比较 n-1 n(n-1)/2 移动 0 3*n(n-1)/2 插入排序 比较 n-1 n(n-1)/2 移动 n-1 n-1+n(n-1)/2 * * 空间复杂性 时间复杂性 顺序搜索/折半搜索算法 名次排序/选择排序/冒泡排序/插入排序算法 矩阵运算 渐进符号(O、Θ 、Ω) 第二章总结 * * 使用 O 分析比较名次排序、选择排序、冒泡排序、插入排序最好和最坏情况下的时间复杂性。列表说明。 作业 * * 程序性能 第2章 * * 为了比较两个完成同一功能的程序的时间复杂性; 为了预测随着实例特征的变化,程序运行时间的变化量。 2.3 Time Complexity * * 按名次排序(Rank sort) 选择排序(Selection sort) 冒泡排序(Bubble sort) 插入排序(Insertion sort) 名次排序优化/选择排序优化/冒泡排序优化 排序算法分析 * * 元素在队列中的名次(rank)可定义为队列中所有比它小的元素数目加上在它左边出现的与它相同的元素数目。 例如,给定一个数组a=[4, 3, 9, 3, 7]作为队列,则各元素
您可能关注的文档
- 交易风险和基差原理分解.ppt
- 0001何谓国学汇编.ppt
- 0.弹力力的测量汇编.ppt
- 浇注式砼铺装施工分解.ppt
- (陈尉华)重庆讲义汇编.ppt
- 爱什么颜色导学案综述.doc
- 胶带机硫化工艺分解.ppt
- 胶带输送机回撤作业规程分解.doc
- 经销商发展瓶颈如何突破分解.ppt
- 经销商管理方法分类分解.ppt
- 2025年吉林省长春市中考历史试题(解析版).pdf
- 2024-2025学年人教版八年级物理下册期末复习练习卷 (含答案).pdf
- 人教版八年级英语上册期末核心考点归纳(含答案).pdf
- 氧化还原滴定与沉淀滴定的相关计算-2024年高考化学考点复习(全国)解析版.pdf
- 数与式一(有理数、实数和代数式,60题)-2021-2025年中考数学复习分类汇编(上海专用).pdf
- 议论文阅读-2024年中考语文一轮复习题型专练.pdf
- 2025年人教版新高一英语学困生专项复习《完形填空》.pdf
- 2023-2025年高考地理试题分类汇编:交通(全国通用)解析版.pdf
- 2025年高考历史试题分类汇编:中国近代史·选择题(全国通用)原卷版.pdf
- 氧化还原滴定与沉淀滴定的相关计算-2024年高考化学考点复习(全国)原卷版.pdf
文档评论(0)