希尔排序
本页面将简要介绍希尔排序。
简介
希尔排序(英语:Shell sort),也称为缩小增量排序法,是 插入排序 的一种改进版本。希尔排序以它的发明者希尔(英语:Donald Shell)命名。
工作原理
排序对不相邻的记录进行比较和移动:
- 将待排序序列分为若干子序列(每个子序列的元素在原始数组中间距相同);
- 对这些子序列进行插入排序;
- 减小每个子序列中元素之间的间距,重复上述过程直至间距减少为 1。
性质
稳定性
希尔排序是一种不稳定的排序算法。
时间复杂度
希尔排序的最优时间复杂度为
希尔排序的平均时间复杂度和最坏时间复杂度与间距序列的选取(就是间距如何减小到 1)有关,比如「间距每次除以 3」的希尔排序的时间复杂度是
空间复杂度
希尔排序的空间复杂度为
实现
C++1
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
Python
1 2 3 4 5 6 7 8 9 10 11 12 |
|
参考资料与注释
build本页面最近更新:2022/3/4 15:41:31,更新历史
edit发现错误?想一起完善? 在 GitHub 上编辑此页!
people本页面贡献者:NachtgeistW, Alisahhh, CroMarmot, Enter-tainer, iamtwz, partychicken, Xeonacid
copyright本页面的全部内容在 CC BY-SA 4.0 和 SATA 协议之条款下提供,附加条款亦可能应用