排序算法的稳定性

**稳定性:**对于一个数,经过多次排序,保留一个数之间的相对次序

在基础类型数据上,稳定性用处不大

在非基础类型上,可以做到对于相同元素来说,排完序相同元素之间的相对次序不变

归并排序在merge的过程中先拷贝左侧的数字,使得归并排序具有稳定性

小和问题在合并时先拷贝右侧部分改变了稳定性

基于比较的排序

|------|------------|---------|-----|
| | 时间复杂度 | 空间复杂度 | 稳定性 |
| 选择排序 | 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) | × |

对排序的改进

综合排序

在样本量较小时,使用插入排序(常数项低的优势)

在样本量较大时,使用快速排序来进行调度(时间复杂度低的优势)

稳定性的考虑

基础类型:快速排序

自定义的类型:归并排序

相关推荐
执笔论英雄8 分钟前
【RL】 ROLL中负载均衡
运维·算法·负载均衡
星辞树12 分钟前
从计数到预测:深入浅出词向量 (Word Vectors) —— Stanford CS224n 作业实战记录
算法
JarryStudy13 分钟前
自动调优在Triton-on-Ascend中的应用:从参数优化到性能极致挖掘
人工智能·算法·昇腾·cann·ascend c
CoderYanger16 分钟前
递归、搜索与回溯-穷举vs暴搜vs深搜vs回溯vs剪枝:13.子集
java·算法·leetcode·机器学习·剪枝·1024程序员节
黑客思维者21 分钟前
底层冗余性原理探秘模型剪枝(Pruning)为何能“无损”压缩模型?
算法·机器学习·剪枝
疯疯癫癫才自由30 分钟前
爬取Leetcode Hot 100 题单
算法·leetcode
WolfGang00732133 分钟前
代码随想录算法训练营Day33 | 322.零钱兑换、279.完全平方数、139.单词拆分、背包总结
算法
CoderYanger37 分钟前
递归、搜索与回溯-综合练习:28.不同路径Ⅲ
java·算法·leetcode·深度优先·1024程序员节
我发在否38 分钟前
Rust > 牛客OJ在线编程常见输入输出练习场
算法·rust
忆湫淮39 分钟前
ENVI 5.6 利用现场标准校准板计算地表反射率具体步骤
大数据·人工智能·算法