【数据结构与算法】希尔排序 python和c++实现

本文详细介绍了希尔排序算法的实现过程,通过C++和Python两种语言展示了代码实现。希尔排序是一种改进的插入排序,通过设定不同的间隔序列逐步减少排序间隔,从而提高排序效率。在排序过程中,对每个间隔内的数据进行插入排序,最终达到整体有序。这种方法使得大量数据的排序速度得到显著提升。
摘要由CSDN通过智能技术生成

算法思路
每一次:固定间隔把数据分组,每一组进行排序
每次比上次选取更小的间隔分组,再每组排序,直到间隔为1

代码
c++:(越看越不明白了,后看)

int gap = length;//length是数组的元素个数,gap是间隔长度
    while (gap>1){
        gap = gap/3 +1;///其实就是生成一个间隔序列
        for (int i = gap; i<length; i+=gap) {
            int current = arr[i];//先把arr[i]中放的东西保存在current中
            int preIndex = i - gap;//上一个同组数据
            while (preIndex >= 0 && arr[preIndex]>current) {//如果同组上个数据大于当前数据
                arr[i]  = arr[preIndex];//就是把这两个格子里的数据调换了位置
                //注意此时current还存着最后的数据
                preIndex -= gap;//再找同组上上个数据
            }
            arr[preIndex+gap] = current;//当找到每组第一个数据时,把current放进去
        }
    }

py:

import numpy as np#import这个为了后面生成测试数据
def shellSort(arr):
    N = len(arr)
    increment = N//2
    while increment > 0:
        i = increment
        while i < N:
            j = i - increment#同组上个数的索引
            tmp = arr[i]#存下arr[i]
            while j >= 0 and arr[j] > tmp:
                arr[j + increment] = arr[j]#这里是把arr[j]存入同组下个数据中了
                j -= increment
            arr[j + increment] = tmp
            i += 1
        increment //= 2
    return arr
if __name__ == '__main__':
    #随机生成20个20以内的数,乱序
    nums=np.random.permutation(20)
    print(shellSort(nums))
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值