希尔排序的简单实现

一、简单介绍

希尔排序实际上是对直接插入排序的优化,直接插入排序的特点是越有序,排的越快,那么实际上希尔排序是将数组进行分组,满足 i - j = gap

然而,不论分多少组,最后一组的gap必须是1

二、排序过程(简单举例)

三、代码实现

java 复制代码
    public static void shellSort(int[] arr) {
        int gap = arr.length;
        while(gap > 1) {
            gap /= 2;
            shell(gap,arr);
        }
    }
    private static void shell(int gap,int[] arr) {
        for(int i = gap; i < arr.length; i++) {
            int temp = arr[i];
            int j = i - gap;
            for(; j >= 0; j -= gap) {
                if(arr[j] > temp) {
                    arr[j + gap] = arr[j];
                }else{
                    arr[j + gap] = temp;
                    break;
                }
            }
            arr[j + gap] = temp;
        }
    }

这里的gap取值只是举个例子,实际上gap的取值依据实际情况而定

四、时间复杂度

希尔排序的时间复杂度不好计算,因为gap的取值方法不固定,不好计算

gap 的取法有多种。最初 Shell 提出取gap=⌊n/2⌋,gap=⌊gap/2⌋ ,直到gap=1 ,后来 Knuth 提出取 gap=⌊gap/3⌋+1。还有人提出都取奇数为好,也有人提出各 gap 互质为好。无论哪一种主张都没有得到证明。

对希尔排序的时间复杂度的分析很困难,在特定情况下可以准确地估算关键码的比较次数和对象移动次数,但想要弄清关键码比较次数和对象移动次数与增量选择之间的依赖关系,并给出完整的数学分析,还没有人能够做到。在 Knuth 所著的《计算机程序设计技巧》第 3 卷中,利用大量的实验统计资料得出,当 nn 很大时,关键码平均比较次数和对象平均移动次数大约在 n^1.251.6*n^1.25 范围内,这是在利用直接插入排序作为子序列排序方法的情况下得到的。

相关推荐
汀、人工智能8 小时前
[特殊字符] 第40课:二叉树最大深度
数据结构·算法·数据库架构·图论·bfs·二叉树最大深度
沉鱼.448 小时前
第十二届题目
java·前端·算法
赫瑞8 小时前
数据结构中的排列组合 —— Java实现
java·开发语言·数据结构
大熊背9 小时前
ISP Pipeline中Lv实现方式探究之三--lv计算定点实现
数据结构·算法·自动曝光·lv·isppipeline
西岸行者9 小时前
BF信号是如何多路合一的
算法
大熊背10 小时前
ISP Pipeline中Lv实现方式探究之一
算法·自动白平衡·自动曝光
罗西的思考10 小时前
【OpenClaw】通过 Nanobot 源码学习架构---(5)Context
人工智能·算法·机器学习
Liudef0611 小时前
后量子密码学(PQC)深度解析:算法原理、标准进展与软件开发行业的影响
算法·密码学·量子计算
OYpBNTQXi12 小时前
SEAL全同态加密CKKS方案入门详解
算法·机器学习·同态加密
yuannl1013 小时前
数据结构----队列的实现
数据结构