04_希尔排序

def shell_sort(data):

    '''

    希尔排序

    :param data:

    :return:

    '''

    length = len(data)

    h = 1

    while h < length / 3:

        h = 3 * h + 1

    while h >= 1:

        for i in range(h,length):

            j=i

            while j >= h and data[j] < data[j-h]:

                data[j], data[j-h] = data[j-h], data[j]

                j -= h

        h = h//3

    return data

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容