数据结构——排序

一、直接插入排序

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

二、希尔排序

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

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

三、快速排序

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

相关推荐
啊我不会诶19 分钟前
【图论】最短路算法
算法·图论
前端梭哈攻城狮32 分钟前
js计算精度溢出,自定义加减乘除类
前端·javascript·算法
秋难降1 小时前
深入解析快速排序:原理、波动根源与优化之道
算法·排序算法·编程语言
睡不醒的kun1 小时前
leetcode算法刷题的第二十一天
数据结构·c++·算法·leetcode·职场和发展·回溯算法·回归算法
小欣加油1 小时前
leetcode 461 汉明距离
c++·算法·leetcode
一起努力啊~3 小时前
算法题打卡力扣第169题:多数元素(easy)
算法·leetcode·哈希算法
水冗水孚3 小时前
通俗易懂地理解深度遍历DFS、和广度遍历BFS
javascript·算法
VT.馒头4 小时前
【力扣】2704. 相等还是不相等
前端·javascript·算法·leetcode·udp
ssshooter4 小时前
上下文工程:为高级大型语言模型构建信息环境
人工智能·算法·设计模式
我也要当昏君4 小时前
5.2 I/O软件
java·网络·算法