【数据结构】8种排序的比较

 

  • 直接插入排序

①所给元素越接近有序,直接插入排序的时间效率越高
②时间复杂度: O(N^2)
③空间复杂度: O(1)
④稳定性: 稳定

  • 希尔排序

①希尔排序是对直接插入排序的优化 
②当gap > 1时,都是预排序,目的是让数组更接近于有序; 当gap == 1时,数组已经接近有序的了,这样就会很快。这样整体  而言,可以达到优化的效果   
③时间复杂度:希尔排序的时间复杂度不好计算,需要进行推导,推导出来平均时间复杂度: O(N^1.3 -N^2)
④空间复杂度:O(1)
⑤稳定性: 不稳定

  • 直接选择排序

①直接选择排序好理解,但是效率不是很好。实际中很少使用
②时间复杂度: O(N^2)
③空间复杂度: O(1)
④稳定性:不稳定(可以调整为稳定的)

  • 堆排序

①堆排序使用堆来选数,效率就高了很多
②时间复杂度: O(N*logN)
③空间复杂度: O(1)
④稳定性:不稳定

  • 冒泡排序

①冒泡排序是一种非常容易理解的排序
②时间复杂度: O(N^2)
③空间复杂度: O(1)
④稳定性:稳定

  • 快速排序

①快速排序整体的综合性能和使用场景都是比较好的,所以才敢叫快速排序
②时间复杂度: O(N*logN)
③空间复杂度: O(logN)
④稳定性:不稳定

  • 归并排序

①归并的缺点在于需要O(N)的空间复杂度,归并排序的思考更多的是解决在磁盘中的外排序问题
②时间复杂度: O(N*logN)
③空间复杂度: O(N)
④稳定性:稳定

  • 计数排序

①计数排序在数据范围集中时,效率很高,但是适用范围及场景有限
②时间复杂度: O(MAX(N,范围))
③空间复杂度: O(范围)
④稳定性:稳定

  • 数据敏感性

数据敏感类型:冒泡排序、快速排序、直接插入排序、希尔排序

数据不敏感类型:直接选择排序、堆排序、归并排序、计数排序

  • 注意:

稳定性:所谓稳定性是指待排序的序列中有两元素相等,排序之后它们的先后顺序不变。

数据敏感:数据敏感是指给定数据无序和有序,对排序的效率影响很大。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值