重要排序算法的总结

重要排序算法的总结

  • 稳定性对基础类型 对象来说毫无意义

  • 稳定性对非基础类型 对象有意义,可以保留之前的相对次序

  • 主要算法时间、空间、稳定性总结

时间 空间 稳定性

SelectionSort O(N^2) O(1) 无

BubbleSort O(N^2) O(1) 有

InsertionSort O(N^2) O(1) 有

MergeSort O(N*logN) O(N) 有

QuickSort O(N*logN) O(logN) 无

HeapSort O(N*logN) O(1) 无

CountSort O(N) O(M) 有

RadixSort O(N) O(M) 有

注意:随机快速排序的复杂度一定要按照概率上的期望指标来估计,用最差的复杂度估计无意义

  • 排序的选择: 一切看你在排序过程中在意什么

    • 数据量非常 的情况下可以做到非常迅速:插入排序
    • 性能优异、实现简单且利于改进 (面对不同业务可以选择不同划分策略)、不在乎稳定性:随机快排
    • 性能优异、不在乎额外空间 占用、具有稳定性:归并排序
    • 性能优异、额外空间占用要求O(1)不在乎稳定性:堆排序
相关推荐
@我漫长的孤独流浪12 小时前
计算机系统核心概念与性能优化全解析
算法·计算机外设
如竟没有火炬12 小时前
接雨水22
数据结构·python·算法·leetcode·散列表
ʚ希希ɞ ྀ12 小时前
二叉树的锯齿层序遍历
数据结构·算法
澈20713 小时前
二叉搜索树:高效增删查的秘诀
java·开发语言·算法
无敌昊哥战神13 小时前
大模型(LLM)推理优化技术全景总结
python·算法·大模型
平行侠13 小时前
A10 恶劣环境传感器信号仿真与统计检验台
算法
洛水水13 小时前
【力扣100题】34.二叉搜索树中第K小的元素
c++·算法·leetcode
_深海凉_13 小时前
LeetCode热题100-翻转二叉树
算法·leetcode·职场和发展
吃好睡好便好14 小时前
在Matlab中绘制抛物三维曲面图
开发语言·人工智能·学习·算法·matlab·信息可视化
tyung14 小时前
用 Go 实现一个生产级 Ring Buffer Queue:环形数组、位运算取模、批量操作全拆解
数据结构·go