Java 插入排序之希尔排序

Java 插入排序之希尔排序

  • 希尔排序是直接插入排序的优化改进版(更高效,也称为缩小增量排序),把数组按 gap 间隔(步长、增量)分成多个子序列,对每个子序列分别进行直接插入排序
  • 初始间隔通常为数组长度的一半,然后逐步缩小间隔,随着数组逐步趋于有序,数据移动的次数逐步减少,直到最后间隔为 1,最终实现高效排序
  • 希尔排序在性能上显著优于直接插入排序,适合中等规模数据,尤其是部分有序的数据
  • 时间复杂度:平均 优于 O(n^2) 最好 O(n log n) 最坏 O(n^2)
  • 空间复杂度:O(1)
  • 稳定性:不稳定
java 复制代码
public static void main(String[] args) {
    int[] arr = {3, 5, 1, 7, 6, 2, 4};
    //初始间隔为数组长度的一半
    int gap = arr.length / 2;
    while (gap >= 1) {
        //对每个间隔为 gap 的子序列进行直接插入排序
        for (int i = gap; i < arr.length; i++) {
            int key = arr[i]; //当前待插入元素 key
            int j = i - gap;
            //从后向前比较,找到插入位置并移动元素(将已排序部分中比 key 大的元素后移 gap 个位置)
            while (j >= 0 && arr[j] > key) {
                arr[j + gap] = arr[j];
                j -= gap;
            }
            //插入 key
            arr[j + gap] = key;
        }
        //逐步缩小间隔
        gap = gap / 2;
    }
    //
    System.out.println("排序后的数组:");
    for (int num : arr) {
        System.out.print(num + " ");
    }
}
//---------------------------------
排序后的数组:
1 2 3 4 5 6 7 
相关推荐
程序员阿达2 分钟前
开题报告之基于SpringBoot框架的路面故障信息上报系统设计与实现
java·spring boot·后端
哞哞不熬夜14 分钟前
JavaEE--SpringIoC
java·开发语言·spring boot·spring·java-ee·maven
滑水滑成滑头15 分钟前
**点云处理:发散创新,探索前沿技术**随着科技的飞速发展,点云处理技术在计算机视觉、自动驾驶、虚拟现实等领域的应用愈发广
java·python·科技·计算机视觉·自动驾驶
千里马-horse24 分钟前
fastddsgen.jar 简介
java·jar·fast dds·fastddsgen
TT哇25 分钟前
【Maven】Maven设置国内源
java·maven
dyj0951 小时前
【Devops-Jenkins自动将Java Maven工程编译成jar、并打成Docker镜像,并上传Harbor】
java·jenkins·devops
gordon~91 小时前
Spring 的bean是安全的吗
java·安全·spring·bean
梵得儿SHI1 小时前
Java 反射机制实战:对象属性复制与私有方法调用全解析
java·开发语言·java反射机制的实际应用·对象属性复制·反射调用私有方法·私有字段·类型兼容性和敏感字段忽略
带刺的坐椅1 小时前
LangChain4j 比 SolonAI 强在哪?弱在哪?
java·ai·langchain·solon·mcp
朝新_2 小时前
【EE初阶 - 网络原理】传输层协议
java·开发语言·网络·笔记·javaee