排序算法的稳定性

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

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

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

归并排序在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) | × |

对排序的改进

综合排序

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

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

稳定性的考虑

基础类型:快速排序

自定义的类型:归并排序

相关推荐
Haooog14 分钟前
替换数字(字符串算法)
算法
hansang_IR14 分钟前
【算法速成课1 | 题解】洛谷P3366 【模板】最小生成树 MST(Prim & Kruskal)
c++·笔记·算法·题解·最小生成树·kruskal·prim
一起努力啊~15 分钟前
算法题打卡力扣第15题:三数之和(mid)
算法·leetcode·职场和发展
快去睡觉~19 分钟前
力扣18:四数之和
算法·leetcode·深度优先
mit6.8249 小时前
8.27 网格memo
c++·算法
jeffery8929 小时前
4056:【GESP2403八级】接竹竿
数据结构·c++·算法
Ghost-Face10 小时前
图论基础
算法
默归10 小时前
分治法——二分答案
python·算法
一枝小雨11 小时前
【数据结构】排序算法全解析
数据结构·算法·排序算法
略知java的景初11 小时前
深入解析十大经典排序算法原理与实现
数据结构·算法·排序算法