数据结构——排序

一、直接插入排序

直接插入排序( Direct Insertion Sort )是一种简单直观的排序算法,适用于 小规模或者部分已排序 的数据集。
它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。稳定

二、希尔排序

是一种基于插入排序的高效排序算法,也是一种非稳定排序算法。
优点:
相较于简单的插入排序,大大减少了数据移动的次数,提高了效率。
不需要额外的存储空间,是原地排序算法。
对于 中等大小 的数据集,效率较高。
缺点:
算法的性能依赖于间隔序列的选择。
是不稳定的排序算法。
在最坏的情况下,其效率仍然不如快速排序、归并排序等其他 O(n log n) 算法。

稳定性:希尔排序是不稳定的排序算法,因为在不同的子序列中插入元素可能会改变相同元素的原始相对顺序。

三、快速排序

快速排序( Quick Sort )是一种高效的排序算法
稳定性:
快速排序是不稳定的排序算法,因为相等的元素可能会因为分区操作而改变原有的顺序。
优点:
平均时间复杂度较好,适合 大规模数据排序
排序过程中数据是原地交换,不需要额外的存储空间(除了递归栈)。
缺点:
最坏情况下性能较差。
不是稳定的排序算法。
步骤
1 、 从数列中挑出一个元素,称为 " 基准 " ( pivot ),通常选择第一个元素
2 、重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)。在这个分区结束之后,该基准就处于数列的中间位置。这个称为分区(partition )操作。
3 、递归地( recursive )把小于基准值元素的子数列和大于基准值元素的子数列排序。

相关推荐
YXXY3132 小时前
模拟算法的介绍
算法
happymaker06262 小时前
简单LRU的实现(基于LinkedHashMap)
算法·leetcode·lru
会编程的土豆2 小时前
【数据结构与算法】空间复杂度从入门到面试:不仅会算,还要会解释
数据结构·c++·算法·面试·职场和发展
普通网友2 小时前
《算法面试必刷:15 个高频 LeetCode 题(附代码)》
算法·leetcode·面试
_深海凉_3 小时前
LeetCode热题100-搜索二维矩阵
算法·leetcode·矩阵
张槊哲3 小时前
C++ 进阶指南:如何丝滑地理解与实践多线程与多进程
开发语言·c++·算法
代码中介商3 小时前
C语言链表完全指南:从单节点到链表管理
c语言·算法·链表
小小de风呀4 小时前
de风——【从零开始学C++】(四):类和对象(下)
开发语言·c++·算法
aqiu1111114 小时前
[特殊字符]【算法日记 14】数论入门神题:最大公约数与最小公倍数的“乘积守恒定律”
算法
保卫大狮兄4 小时前
一文讲清:仓库管理最核心的10个公式
人工智能·算法·仓库管理