数据结构——排序

一、直接插入排序

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

二、希尔排序

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

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

三、快速排序

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

相关推荐
ʚ希希ɞ ྀ9 小时前
单词拆分----dp
算法
智者知已应修善业10 小时前
【51单片机LED闪烁10次数码管显示0-9】2023-12-14
c++·经验分享·笔记·算法·51单片机
智者知已应修善业10 小时前
【51单片机2按键控制1个敞亮LED灯闪烁和熄灭】2023-11-3
c++·经验分享·笔记·算法·51单片机
AI算法沐枫10 小时前
大模型 | 大模型之机器学习基本理论
人工智能·python·神经网络·学习·算法·机器学习·计算机视觉
吃着火锅x唱着歌10 小时前
LeetCode 1019.链表中的下一个更大节点
算法·leetcode·链表
凌波粒10 小时前
LeetCode--404.左叶子之和(二叉树)
算法·leetcode·职场和发展
paeamecium10 小时前
【PAT甲级真题】- A+B in Hogwarts
c++·算法·pat考试·pat
青山师11 小时前
二叉树与BST深度解析:遍历算法与平衡策略
数据结构·算法·面试·二叉树·算法与数据结构·java面试·数据结构与算法分析