常见的三种排序算法(堆排、快排、归并排序)的比较总结

这两天看了一下常见的三种排序算法:堆排序、快速排序、归并排序。三种排序算法的分析

网上的文章很多,随便一搜就一大堆,这里就不再赘述。

下面总结一下三种算法特点:

一、快速排序

最常用的排序算法,速度通常也是最快的。

时间复杂度:O(n*logn)
最坏:O(n^2)
空间复杂度:O(n*lgn)
不稳定(比如 5 3 3 4 3 8 9 10 11 这个序列,在中枢元素5和3交换就会把元素3的稳定性打乱)


二、堆排序

时间复杂度:O(n*logn)

特别适用于数据量很大的场合(百万级数据)。因为快排和归并排序都是基于递归的,数据量很大的

情况下容易发生堆栈溢出。

排序速度略低于快排。

也是一种不稳定的排序算法。比如 3 27 27 36,如果堆顶3先输出,则第三层(最后一个27)跑到堆顶,

然后堆稳定,继续输出堆顶,是刚才那个27, 这样说明后面的27先于第二个位置的27输出,不稳定。


三、归并排序

值得注意的是,它是一种稳定的排序算法。

时间复杂度:O(n*logn)

与前两种排序算法不同的是,归并排序需要额外的数组开销。


注:所谓排序的稳定性,是指在排序过程中,在对a关键字排序后会不会改变其他关键字的顺序。

在比较有相同关键字序列的情况下,稳定的排序会将较早出现的元素排在前面,而不是后面。

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值