排序四 希尔排序

希尔排序(Shell Sort)

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

时间复杂度:最好 O(n)=O(nlogn);平均O(n)=depends on gap;最差O(n)=O(n²)
空间复杂度:O(n)=O(1)
稳定性:    不稳定

算法描述

  1. 定义一个间隔增量gap,gap小于待排序序列长度。
  2. 根据增量gap将待排序序列进行分组,对每一组进行简单插入排序。
  3. gap减小。若gap>=1则继续执行步骤1,否则排序结束。
    Shell Sort
    图片来自维基百科

排序示例

现有一个长度为10待排序数组S:[9,1,5,3,8,7,2,4,6,0]
第一次选择增量为gap=S.Length/2,以gap=gap/2的方式缩小增量
Shell Sort

示例代码

public static void ShellSort(int[] S){ //C#
    for (int gap = S.Length / 2; gap > 0; gap /= 2){
        for (int i = gap; i < S.Length; i++){
            for (int j = i - gap; j >= 0 && S[j] > S[j+gap]; j -= gap){
                S.Swap(j, j + gap);
            }
        }
    }
}
def shell_sort(s):  #Python
    gap = len(s) // 2
    while gap > 0:
        for i in range(gap, len(s)):
            for j in range(i-gap, -1, -gap):
                if s[j] <= s[j+gap]:
                    break
                s[j], s[j+gap] = s[j+gap], s[j]
        gap //= 2

文中若有什么错误,欢迎留言指正。

转载请保留出处:http://blog.csdn.net/x1060549/article/details/78780085

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值