首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

排序算法总结(python版)-4

排序算法总结(python版)-4

希尔排序(Shell Sort)

Shell发明,第一个突破O(n2)的排序算法,是简单插入排序的改进版。它与插入排序的不同之处在于,它会优先比较距离较远的元素。希尔排序又叫缩小增量排序。
算法描述

先将整个待排序的记录序列分割成为若干子序列分别进行直接插入排序,具体算法描述:

    选择一个增量序列t1,t2,…,tk,其中ti>tj,tk=1;
    按增量序列个数k,对序列进行k 趟排序;
    每趟排序,根据对应的增量ti,将待排序列分割成若干长度为m 的子序列,分别对各子表进行直接插入排序。仅增量因子为1 时,整个序列作为一个表来处理,表长度即为整个序列的长度。

    def ShellSort(ls):
        increment = len(ls)
        while(increment > 1):
            increment = increment//3 + 1
            for i in range(increment,len(ls)):
                if ls[i] < ls[i-increment]:
                    tmp = ls[i]
                    j = i - increment
                    while(j >= 0 and ls[j] > tmp):
                        ls[j + increment] = ls[j]
                        j -= increment
                    ls[j + increment] = tmp
            print(ls)
        return ls
返回列表