排序算法的稳定性

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

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

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

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

对排序的改进

综合排序

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

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

稳定性的考虑

基础类型:快速排序

自定义的类型:归并排序

相关推荐
郝学胜-神的一滴29 分钟前
深度学习优化核心:梯度下降与网络训练全解析
数据结构·人工智能·python·深度学习·算法·机器学习
Je1lyfish1 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
许彰午1 小时前
03-二叉树——从递归遍历到非递归实现
java·算法
Brilliantwxx1 小时前
【C++】 vector(代码实现+坑点讲解)
开发语言·c++·笔记·算法
NorburyL3 小时前
DPO笔记
深度学习·算法
老纪的技术唠嗑局3 小时前
深度解析 LLM Wiki / Obsidian-Wiki / GBrain:Agent 时代知识的“自组织”与“自进化”
大数据·数据库·人工智能·算法
YXXY3136 小时前
模拟算法的介绍
算法
happymaker06266 小时前
简单LRU的实现(基于LinkedHashMap)
算法·leetcode·lru
会编程的土豆7 小时前
【数据结构与算法】空间复杂度从入门到面试:不仅会算,还要会解释
数据结构·c++·算法·面试·职场和发展
普通网友7 小时前
《算法面试必刷:15 个高频 LeetCode 题(附代码)》
算法·leetcode·面试