排序(1):希尔排序(Shell's Sort)

希尔排序

来源:百度百科

希尔排序(Shell’s Sort)是插入排序的一种又称“缩小增量序”(Diminishing Increment Sort),是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因D.L.Shell于1959年提出而得名。
希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。

1. 算法思想 (实例演示)

假设有这样一组数 {13, 14, 94, 33, 82, 25, 59, 94, 65, 23, 45, 27, 73, 25, 39, 10},如果我们以步长为 5 开始进行排序:

13, 14, 94, 33, 82,
 25, 59, 94, 65, 23, 
 45, 27, 73, 25, 39, 
 10

然后我们对每列进行排序(即小的数放前):

10 14 73 25 23
13 27 94 33 39
25 59 94 65 82
45

将上述四行数字,依序接在一起时我们得到:{10, 14, 73, 25, 23, 13, 27, 94, 33, 39, 25, 59, 94, 65, 82, 45},然后再以 3 为步长

10 14 73
25 23 13
27 94 33
39 25 59
94 65 82
45

最后以 1 为步长进行排序(此时就是简单的插入排序了)。

2. 步长选择

第一次分组步长(增量)=n/2
第二次步为第一次的步长/2

直到步长等于1算法结束

3. 优劣

1. 不需要大量的辅助空间,和归并排序一样容易实现。
2. 时间复杂度: 平均情况:O(nlog2n) 根据步长序列的不同而不同、最坏情况O(nlog2n),最好情况O(n)
3. 空间复杂度: O(1)
4、稳定性: 不稳定
5、复杂度:较直接插入排序复杂

Python代码实现

# -*-coding:utf-8 -*-
def shellSort(input_list):
    length = len(input_list)
    if length <= 1:
        return input_list
    sorted_list = input_list
    gap = length // 2
    while gap > 0:
        for i in range(gap, length):
            j = i - gap
            temp = sorted_list[i]
            while j >= 0 and temp < sorted_list[j]:
                sorted_list[j+gap] = sorted_list[j]
                j -= gap
            sorted_list[j+gap] = temp
        gap //= 2
    return sorted_list 
 
if __name__ == '__main__':
    input_list = [50, 123, 543, 187, 49, 30, 0, 2, 11, 100]
    print('排序前:', input_list)
    sorted_list = shellSort(input_list)
    print('排序后:', sorted_list)

本站整理自:
https://cuijiahua.com/blog/2017/12/algorithm_3.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值