- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
典型比较排序法时间复杂度对比农民伯伯
典型比较排序法时间复杂度对比
2008-09-12 13:56
平均情况
最好情况
最坏情况
归并排序
O(nlogn)
O(nlogn)
O(nlogn)
快速排序
O(nlogn)
O(nlogn)
O(n2)
希尔排序
O(n1.5)
O(n)
O(n1.5)
插入排序
O(n2)
O(n)
O(n2)
选择排序
O(n2)
O(n2)
O(n2)
O(nlogn)
选择排序:时间复杂度O(n2)
冒泡排序:时间复杂度O(n2)
归并排序占用附加存储较多,需要另外一个与原待排序对象数组同样大小的辅助数组。这是这个算法的缺点。
基数排序:时间复杂度是O ( d ( n+radix ) ),但d一般不能取常数,d=logn,所以时间复杂度为O(nlogn),当k=n时,为O(n)
线性时间排序的有:计数、基数、桶排序。
在前面几节中讨论了内部排序和外部排序的方法。对于内部排序主要介绍了五大类排序方法:插入排序(直接插入排序、折半插入排序和希尔排序)、交换排序(冒泡排序和快速排序)、选择排序(简单选择排序和堆排序)、归并排序和基数排序。详细讨论了各种排序方法的基本原理,并从时间复杂性、空间复杂性以及排序的稳定性三方面讨论了各种排序方法的时效性,介绍了各排序方法的实现算法及其存在的优缺点。如果待排序的数据量很小,最好选择编程简单的排序算法,因为在这种情况下采用编程复杂、效率较高的排序方法所能节约的计算机时间是很有限的。反之,如果待处理的数据量很大,特别是当排序过程作为应用程序的一部分需要经常执行时,就应该认真分析和比较各种排序方法,从中选出运行效率最高的方法。
下面具体比较一下各种排序方法,以便实现不同的排序处理。
(1) 插入排序的原理:向有序序列中依次插入无序序列中待排序的记录,直到无序序列为空,对应的有序序列即为排序的结果,其主旨是“插入”。
(2) 交换排序的原理:先比较大小,如果逆序就进行交换,直到有序。其主旨是“若逆序就交换”。
(3) 选择排序的原理:先找关键字最小的记录,再放到已排好序的序列后面,依次选择,直到全部有序,其主旨是“选择”。
(4) 归并排序的原理:依次对两个有序子序列进行“合并”,直到合并为一个有序序列为止,其主旨是“合并”。
(5) 基数排序的原理:按待排序记录的关键字的组成成分进行排序的一种方法,即依次比较各个记录关键字相应“位”的值,进行排序,直到比较完所有的“位”,即得到一个有序的序列。
各种排序方法的工作原理不同,对应的性能也有很大的差别,下面通过一个表格可以看到各排序方法具体的时间性能、空间性能等方面的区别。
依据这些因素,可得出如下几点结论:
(1) 若n较小(如n值小于50),对排序稳定性不作要求时,宜采用选择排序方法,若关键字的值不接近逆序,亦可采用直接插入排序法。但如果规模相同,且记录本身所包含的信息域比较多的情况下应首选简单选择排序方法。因为直接插入排序方法中记录位置的移动操作次数比直接选择排序多,所以选用直接选择排序为宜。
(2) 如果序列的初始状态已经是一个按关键字基本有序的序列,则选择直接插入排序方法和冒泡排序方法比较合适,因为“基本”有序的序列在排序时进行记录位置的移动次数比较少。
(3) 如果n较大,则应采用时间复杂度为O(nlog2n)的排序方法,即快速排序、堆排序或归并排序方法。快速排序是目前公认的内部排序的最好方法,当待排序的关键字是随机分布时,快速排序所需的平均时间最少;堆排序所需的时间与快速排序相同,但辅助空间少于快速排序,并且不会出现最坏情况下时间复杂性达到O(n2)的状况。这两种排序方法都是不稳定的,若要求排序稳定则可选用归并排序。通常可以将它和直接插入排序结合在一起用。先利用直接插入排序求得两个子文件,然后,再进行两两归并。
排序是软件设计中最常用的运算之一。排序分为内部排序和外部排序,涉及多种排序的方法。
内部排序是将待排序的记录全部放在内存的排序。本章所讨论的各种内部排序的方法大致可分为:插入排序、交换排序、选择排序、归并排序和基数排序。
插入排序算法的基本思想是:将待序列表看做是左、右两部分,其中左边为有序序列,右边为无序序列,整个排序过程就是将右边无序序列中的记录逐个插入到左边的有序序列中。直接插入排序是这类排序算法中最基本的一种,然而,该排序法时间性能取决于待排序记录的初始特性。折半插入排序是通过折半查找的方法在有序表中查找记录插入位置的排序方法。希尔排序算法是一种改进的插入排序,其基本思想是:将待排记录序列划分为若干组,在每组内先进行直接插入排序,以使组内序列基本有序,然后再对整个序列进行直
您可能关注的文档
最近下载
- ISO_1406 4-3_中文版.pdf VIP
- 中学生冬季安全教育.pptx VIP
- 07MS101:市政给水管道工程及附属设施.pdf VIP
- 中学生冬季安全教育课件.ppt VIP
- 初中历史教学中的历史思维能力培养.pptx VIP
- 发那科机器人Line Tracking(直线追踪)FANUC.pdf VIP
- 中学生国家网络安全法.pptx VIP
- 一种氧化透明质酸-PDRN-多肽纳米乳液及其制备方法.pdf VIP
- House of David《大卫王朝(2025)》第一季第三集完整中英文对照剧本.docx VIP
- House of David《大卫王朝(2025)》第一季第一集完整中英文对照剧本.docx VIP
原创力文档


文档评论(0)