排序算法的稳定性

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

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

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

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

对排序的改进

综合排序

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

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

稳定性的考虑

基础类型:快速排序

自定义的类型:归并排序

相关推荐
Jasmine_llq2 小时前
《CF280C Game on Tree》
数据结构·算法·邻接表·深度优先搜索(dfs)·树的遍历 + 线性累加统计
小棠师姐2 小时前
支持向量机(SVM)入门:超平面与核函数的通俗解释
算法·python机器学习·支持向量机svm·超平面可视化·核函数应用
im_AMBER2 小时前
Leetcode 102 反转链表
数据结构·c++·学习·算法·leetcode·链表
今儿敲了吗2 小时前
01|多项式输出
c++·笔记·算法
Xの哲學3 小时前
深入剖析Linux文件系统数据结构实现机制
linux·运维·网络·数据结构·算法
AlenTech3 小时前
200. 岛屿数量 - 力扣(LeetCode)
算法·leetcode·职场和发展
C雨后彩虹3 小时前
竖直四子棋
java·数据结构·算法·华为·面试
不如自挂东南吱4 小时前
空间相关性 和 怎么捕捉空间相关性
人工智能·深度学习·算法·机器学习·时序数据库
洛生&4 小时前
Elevator Rides
算法
2501_933513044 小时前
关于一种计数的讨论、ARC212C Solution
算法