排序——算法总结

排序算法的稳定性是指:排序后相同的元素相对顺序与排序前相对顺序一致

算法时间复杂度额外空间复杂度稳定性
选择排序O(N^2)O(1)
冒泡排序O(N^2)O(1)
插入排序O(N^2)O(1)
归并排序O(N*logN)O(N)有(相同情况先拷贝左组)
随机快排(常数时间最优)O(N*logN)O(logN)
堆排序O(N*logN)O(1)
计数排序O(N)O(M)
基数排序O(N)O(N) 数据量大时实际是O(N * log(10,max))

总结

1.不基于比较的排序,对样本数据有严格要求,不易改写
2.基于比较的排序,只要规定好两个样本怎么比大小就可以直接复用
3.基于比较的排序,时间复杂度的极限是O(NlogN)
4.时间复杂度O(N
logN)、额外空间复杂度低于O(N)、且稳定的基于比较的排序是不存在的
5.为了绝对的速度选快排,为了省空间选堆排,为了稳定性选归并排序

常见的坑

1.归并排序的额外空间复杂度可以变成O(1),"归并排序 内部缓存法“,但是将变得不再稳定
2."原地归并排序"是垃圾帖,会让时间复杂度变成O(N^2)
3.快速排序稳定性改进,“01 stable sort”,但是会对样本数据要求更多
4.在整型数组中,请把奇数放在数组的左边,偶数放在数组的右边,要求所有奇数之间原始的相对次序不变,所有偶数之间原始相对次序不变。在时间复杂度O(N),空间复杂度O(1)的情况下完成这种算法。是学术问题,需要限制数据范围,有论文,不过无价值,无意义。

工程上对排序的改进

1.稳定性的考虑
基础类型,快排,引用类型,归并排序
优化:系统库提供的排序算法可能会使用混合排序的方式,改变常数项
2.充分利用O(N*logN)和O(N^2)排序各自的优势

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

metabit

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值