2.1.6 希尔排序 Shell Sort

希尔排序可以用于大型数组,他对任意排序的数组表现也很好。

希尔排序为了加快速度简单地改进了插入排序,交换不相邻的元素以对数组的局部进行排序,并最终用插入排序将局部有序的数组排序。

希尔排序比插入排序和选择排序要快得多,并且数组越大,优势越大。

希尔排序更高效的原因是它权衡了子数组的规模和有序性。排序之初,各个子数组都很短,排序之后的字数组都是部分有序的,这两种情况都很适合插入排序。

Python

A = [70, 90, 31, 37, 10, 1, 48, 60, 33, 80]

def shell_sort(arr):
    gap = len(arr)
    lenght = len(arr)
    while(gap > 1):
        gap = gap//2
        for i in range(gap, lenght):
            for j in range(i, 0, -gap):
                if arr[j] < arr[j-gap]:
                    arr[j], arr[j-gap] = arr[j-gap], arr[j]
    return arr

print(shell_sort(A))

Java

public class Shell{
    public static void sort(Comparable[] a){
        int N = a.length;
        int h = 1;
        while(h < N /3) h = 3 * h + 1; // 1, 4, 13, 40, 121...
        while(h >= 1){
            for(int i = h; i < N; i++){
                for(int j = i; j >=h && less(a[j], a[j-h]; j -= h)
                    exch(a, j, j-h)
            }
            h = h / 3;
        }
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1 初级排序算法 排序算法关注的主要是重新排列数组元素,其中每个元素都有一个主键。排序算法是将所有元素主键按某种方...
    深度沉迷学习阅读 1,440评论 0 1
  • 数据结构与算法--排序之冒泡、选择、插入、希尔 我们关注的主要对象是重新排列数组元素的算法,每个元素都有一个主键,...
    sunhaiyu阅读 1,159评论 2 12
  • 一、对比分析图 均按从小到大排列 k代表数值中的"数位"个数 n代表数据规模 m代表数据的最大值减最小值 稳定性:...
    leo567阅读 1,253评论 0 1
  • 那一年,大哥高考落第时,我十八岁。 他蛰伏了几个月后,因为生活还要继续,他就开始跟着村上的基建队到城里干活了。 他...
    水云汀阅读 649评论 8 6
  • 山本耀司:我们都是靠着努力,从受人嫌弃,变成被人喜爱。这一年来,你努力了吗? 你觉得老了那就对了,你的孩子已经...
    烟灰女人阅读 526评论 2 8