典型比较排序法时间复杂度对比

认证主体:孙**(实名认证)

IP属地:天津

下载本文档

2、不能取常数,d=logn,所以时间复杂度 为 O(nlogn),当 k=n 时,为 0(n)排序方法比较次数移动次数稳定 性附加存储最好最 差最好最 差最好最 差直接插入排序nI"02 n1折半插入排序n log2n02 n1起泡排序nn202 nA1快速排序nlog2n2 nn log2n2 nXlog2nn2简单选择排序2 n0nBH1锦标赛排序n gnn log2nn堆排序n log2nn log2nX1归并排序n log2nn log2nAn线性时间排序的有:计数、基数、桶排序。在前面几节中讨论了内部排序和外部排序的方法。对于内部排序主要介绍了五大类排序方法:插入排序(直接插

3、入排序、折半插入排序和希尔排序)、交换排序(冒泡排序和快速排序)、选择排序(简单选择排序和堆排序)、归并排序和基数排序。详细讨论了各种排序方法的基本原理,并从时间复杂性、空间复杂性以及排序的稳定性三方面讨论了各种排序方 法的时效性,介绍了各排序方法的实现算法及其存在的优缺点。如果待排序的数据量很小, 最好选择编程简单的排序算法,因为在这种情况下采用编程复杂、效率较高的排序方法所 能节约的计算机时间是很有限的。反之,如果待处理的数据量很大,特别是当排序过程作 为应用程序的一部分需要经常执行时,就应该认真分析和比较各种排序方法,从中选出运 行效率最高的方法。下面具体比较一下各种排序方法,以便实现不

4、同的排序处理。(1) 插入排序的原理:向有序序列中依次插入无序序列中待排序的记录,直到无序序列为空,对应的有序序列即为排序的结果,其主旨是插入”(2) 交换排序的原理:先比较大小,如果逆序就进行交换,直到有序。其主旨是 “若逆序 就交换 ”。(3) 选择排序的原理:先找关键字最小的记录,再放到已排好序的序列后面,依次选择, 直到全部有序,其主旨是 “选择 ”。(4) 归并排序的原理: 依次对两个有序子序列进行 “合并 ”,直到合并为一个有序序列为止, 其主旨是 “合并 ”。(5) 基数排序的原理: 按待排序记录的关键字的组成成分进行排序的一种方法, 即依次比 较各个记录关键字相应 “位 ”的值

5、,进行排序,直到比较完所有的 “位”,即得到一个有序的 序列。各种排序方法的工作原理不同,对应的性能也有很大的差别,下面通过一个表格可以 看到各排序方法具体的时间性能、空间性能等方面的区别。依据这些因素,可得出如下几点结论:(1) 若 n 较小(如 n 值小于 50),对排序稳定性不作要求时,宜采用选择排序方法,若 关键字的值不接近逆序,亦可采用直接插入排序法。但如果规模相同,且记录本身所包含 的信息域比较多的情况下应首选简单选择排序方法。因为直接插入排序方法中记录位置的 移动操作次数比直接选择排序多,所以选用直接选择排序为宜。(2) 如果序列的初始状态已经是一个按关键字基本有序的序列, 则选

6、择直接插入排序方 法和冒泡排序方法比较合适,因为 “基本 ”有序的序列在排序时进行记录位置的移动次数比 较少。(3) 如果 n 较大,则应采用时间复杂度为 O(nlog2n) 的排序方法,即快速排序、堆排序 或归并排序方法。快速排序是目前公认的内部排序的最好方法,当待排序的关键字是随机 分布时,快速排序所需的平均时间最少;堆排序所需的时间与快速排序相同,但辅助空间 少于快速排序,并且不会出现最坏情况下时间复杂性达到0(n2)的状况。这两种排序方法都是不稳定的,若要求排序稳定则可选用归并排序。通常可以将它和直接插入排序结合在一 起用。先利用直接插入排序求得两个子文件,然后,再进行两两归并。排序是

7、软件设计中最常用的运算之一。排序分为内部排序和外部排序,涉及多种排序的方 法。内部排序是将待排序的记录全部放在内存的排序。本章所讨论的各种内部排序的方法 大致可分为:插入排序、交换排序、选择排序、归并排序和基数排序。插入排序算法的基本思想是:将待序列表看做是左、右两部分,其中左边为有序序列, 右边为无序序列,整个排序过程就是将右边无序序列中的记录逐个插入到左边的有序序列 中。直接插入排序是这类排序算法中最基本的一种,然而,该排序法时间性能取决于待排 序记录的初始特性。折半插入排序是通过折半查找的方法在有序表中查找记录插入位置的 排序方法。希尔排序算法是一种改进的插入排序,其基本思想是:将待排记

8、录序列划分为 若干组,在每组内先进行直接插入排序,以使组内序列基本有序,然后再对整个序列进行 直接插入排序。其时间性能不取决于待排序记录的初始特性。交换排序的基本思想是:两两比较待排序列的记录关键字,发现逆序即交换。基于这 种思想的排序有冒泡排序和快速排序两种。冒泡排序的基本思想是:从一端开始,逐个比 较相邻的两个记录,发现逆序即交换。然而,其时间性能取决于待排序记录的初始特性。 快速排序是一种改进的交换排序,其基本思想是:以选定的记录为中间记录,将待排序记 录划分为左、右两部分,其中左边所确记录的关键字不大于右边所有记录的关键字,然后 再对左右两部分分别进行快速排序。选择排序的基本思想是:在

9、每一趟排序中,在待排序子表中选出关键字最小或最大的 记录放在其最终位置上。直接选择排序和堆排序是基于这一思想的两个排序算法。直接选 择排序算法采用的方法较直观:通过对待排序子表中完整地比较一遍以确定最大(小)记录,并将该记录放在子表的最前 (后)面。堆排序就是利用堆来进行的一种排序,其中堆是一个满足特定条件的序列,该条件用完全二叉树模型表示为每个结点不大于(小于)其左、右孩子的值。利用堆排序可使选择下一个最大(小)数的时间加快,因而提高算法的时间复杂度,达到O(nlog2n)。归并排序是一种基于归并的排序,其基本操作是指将两个或两个以上的有序表合并成 一个新的有序表。首先将n个待排序记录看成

10、n个长度为1的有序序列,第一趟归并后变成n/2个长度为2或1的有序序列;再进行第二趟归并,如此反复,最终得到一个长度为n的有序序列。归并排序的时间复杂度为O(nlog2n),最初待排序记录的排列顺序对运算时间影响不大,不足之处就是需要占用较大的辅助空间。基数排序是利用多次的分配和收集过程进行排序。关键字的长度为d,其每位的基数为r。首先按关键字最低位值的大小依次将记录分配到r个队列中,然后依次收集;随后按关键字次最低位值的大小依次对记录进行分配并收集;如此反复,直到完成按关键字最高位 的值对记录进行分配和收集。基数排序需要从关键字的最低位到最高位进行d趟分配和收集,时间复杂度为 O(d(n+r),其缺点是多占用额外的内存空间存放队列指针。外部排序是对存放在外存的大型文件的排序,外部排序基于对有序归并段的归并,而 其初始归并段的产生基于内部排序。排序方法时间复杂度空间复杂度稳定性复杂性平均情况最坏情况最好情况直接插入排 序O (n2)O (n2)O (n)O(1)稳定简单折半插入排 序O (n2)O (n2)O (n)O(1)稳定一般希尔排序0(n )O(1)不稳定较复杂简单选择排序O (n2)O (n2)O (n2)O(1)不稳定简单堆排序O(nlog2n)O(nlog2n)O

0/150

联系客服

本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。人人文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知人人文库网,我们立即给予删除!

THE END
0.NOI大纲文字收藏版3. 排序算法 ·【5】归并排序 ·【5】快速排序 ·【6】堆排序 ·【6】树形选择排序(锦标赛排序) ·【5】桶排序 ·【6】基数排序 4. 字符串相关算法 ·【5】字符串匹配算法——KMP 5. 搜索算法 ·【6】搜索的剪枝优化 ·【6】记忆化搜索 ·【7】启发式搜索 ·【7】双向宽度优先搜索 ·【7】迭代jvzq<84yyy4489iqe0ipo8hqpvkov87312?1385217927h>;57=549:0ujznn
1.数据结构之树形选择排序(锦标赛排序)锦标赛排序也叫树形选择排序,是一种按照锦标赛的思想进行选择的排序方法,该方法是在简单选择排序方法上的改进。简单选择排序,花费的时间大部分都浪费在值的比较上面,而锦标赛排序刚好用树保存了前面比较的结果,下一次比较时直接利用前面比较的结果,这样就大大减少比较的时间,从而降低了时间复杂度,由O(n^2)降到O(jvzquC41dnuh0lxfp0tfv8qkjcu28::525:11jwvkerf1mjvckrt1@=;5::15
2.漫画:什么是“锦标赛排序”?漫画:什么是 “锦标赛排序” ? [导读]你了解选择排序吗? ——— 第二天 ——— ——— 如图中所示,我们把原本的冠军选手5排除掉,在四分之一决赛和他同一组的选手6就自然获得了直接晋级。 接下来的半决赛,选手7打败选手6晋级;在总决赛,选手7打败选手3晋级,成为了新的冠军。 因此我们可以判断出,选手7是总jvzquC41yy}/4:ne0eun1jwvkerf1A=:93?/j}rn
3.漫画:什么是“锦标赛排序”?接下来的半决赛,选手7打败选手6晋级;在总决赛,选手7打败选手3晋级,成为了新的冠军。 因此我们可以判断出,选手7是总体上的亚军。 假如给定如下数组,要求从小到大进行升序排列: 第一步,我们根据数组建立一颗满二叉树,用于进行“锦标赛式”的多层次比较。数组元素位于二叉树的叶子结点,元素数量不足时,用空结点补齐。jvzquC41fg|fnxugt0gmk‚zp0eun1jwvkerf1B5655:
4.快速排序本页面将简要介绍快速排序。定义 快速排序(英语:Quicksort),又称分区交换排序(英语:partition-exchange sort),简称「快排」,是一种被广泛运用的排序算法。基本原理与实现 过程 快速排序的工作原理是通过 分治 的方式来将一个数组排序。快速排序分为三个过程:将jvzq<84qk/}jmr3eqo5cc|ne1s{jet2uqtz0
5.14.8树形选择排序·LeetCode算法练习个人总结(Java)·看云14.8 树形选择排序(堆排序前身) 基本概念: 树形选择排序(Tree Selection Sort),又称锦标赛排序(Tournament Sort),也可以算得上堆排序的前身,是一种按照锦标赛思想进行选择排序的方法。它是根据节点的大小, 建立树, 输出树的根节点, 并把此重置为最大值, 再重构树,因为树中保留了一些比较的逻辑, 所以减少了jvzquC41yy}/mjsenq{e0ls1ocrjorsi1nkfvltfg1=54B:3
6.希尔排序,⌊log2⁡n⌋}(从大到小),则希尔排序算法的时间复杂度为 𝑂(𝑛3/2)O(n3/2)。 命题2 若间距序列为 𝐻 ={𝑘 =2𝑝 ⋅3𝑞 ∣𝑝,𝑞 ∈ℕ,𝑘 ≤𝑛}H={k=2p⋅3q∣p,q∈N,k≤n}(从大到小),则希尔排序算法的时间复杂度为 𝑂(𝑛log2⁡𝑛)O(nlog2⁡n)。jvzquC41qk3xktn0qtm0djxke1yiguq/uqxu1
7.数据结构求答案单选题第1题(2)分排序趟数与序列的原始状态有时间复杂性为O(nlog2n)且空间复杂性为O(1)的排序方法是( )。 A、归并排序 B、堆排序 C、快速排序 D、锦标赛排序 第15题 (2) 分 要将现实生活中的数据转化为计算机所能表示的形式,其转化过程依次为( )。 A、逻辑结构、存储结构、机外表示 B、存储结构、逻辑结构、机外表示 C、机外表示、逻辑结构、存储结构 DjvzquC41yy}/|‚gcpi4dqv4swgyukxs1::9fhj89d3jg9kf:3d:9h=fhc5?9d;=f0jznn
8.中国石油大学数据结构试题及答案C 锦标赛排序 D 快速排序 6、设有两个串t和p,求p在t中首次出现的位置的运算叫做()。 A 求子串 B 模式匹配 C 串替换D 串连接 7、在数组A中,每一个数组元素A[i][j]占用3个存储字,行下标i从1到8,列下标j从1到10。所有数组元素相继存放于一个连续的存储空间中,则存放该数组至少需要的存储字数是()jvzquC41o0972mteu0tfv8iqe1>43<>7;7<70qyon
9.经典排序算法详解对象的移动次数不超过关键码的比较次数,所以锦标赛排序总的时间复杂度为O(nlog2n)。 多了附加存储。如果有 n 个对象,必须使用至少 2n-1 个结点来存放胜者树。 稳定 6、堆排 堆排序分为两个步骤:第一步,根据初始输入数据,利用堆的调整算法 FilterDown( ) 形成初始堆,第二步,通过一系列的对象交换和重新调jvzquC41dnuh0lxfp0tfv8~wejkoiuncpanbry~1ctzjeuj1fgzbkux174945@=9
10.Python选择排序中的树形选择排序python选择排序里面主要讲了三个排序,分别是简单选择排序、树形选择排序、堆排序。今天这篇文章主要讲树形选择排序,树形选择排序也被称为锦标赛排序,树形选择排序运用了锦标赛的思想进行排序,树形选择排序是指首先对n个记录的关键字进行两两比较,然后在n/2个较小者之间再进行两两比较,如此重复,直至选出最小的记录为止。jvzquC41yy}/lk:30pku1jwvkerf1;7;72?/j}r