重要排序算法的总结

重要排序算法的总结

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

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

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

时间 空间 稳定性

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)不在乎稳定性:堆排序
相关推荐
CoovallyAIHub22 分钟前
化工厂气体泄漏怎么用AI检测?30张图3D重建气体泄漏场景——美国国家实验室NeRF新研究
深度学习·算法·计算机视觉
颜酱12 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
zone773917 小时前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub20 小时前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub20 小时前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉
CoovallyAIHub20 小时前
Claude Code 突然变成了 66 个专家?这个 5.8k Star 的开源项目,让我重新理解了什么叫"会用 AI"
深度学习·算法·计算机视觉
兆子龙20 小时前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
CoovallyAIHub1 天前
9个视觉语言模型工厂实测:Qwen 87.9%碾压全场,你的显卡能跑哪个?
算法
SparkX开源AI知识库1 天前
手摸手带你安装OpenClaw并对接飞书
算法·架构
一语07161 天前
3分钟搞懂深度学习AI:实操篇:卷积层
人工智能·算法