希尔排序(简单易懂,图文并貌,插入排序)java代码实现

简介: 希尔排序(简单易懂,图文并貌,插入排序)java代码实现

希尔排序是直接插入排序算法的一种更高效的改进版本。

希尔排序思想:

按照增量d对其进行分组,每组内部分别进行直接插入排序;
(如果不太懂直接插入排序的java具体实现方法,可参考本人所写另一篇博文:直接插入排序
一般首先取d等于序列长度的一半,然后以后每次减半,直到增量等于1.

下面是本人用ProcessOn所绘制的排序过程图:

(以11个数为例进行说明,请大家认真分析此图,耐心一点,写得很详细,看完此图应该会有所收获)
说明:
下图中不同颜色的线代表不同的分组,例如下图中第一行黑色线相连的有426,-2,23,说明426,-2,23被分为一组,并对426,-2,23进行直接插入排序;
第一行蓝色线相连的有62 ,0说明62,0被分为一组;
同理下面的连线分组都是这样的。
作者:喻世文

java实现代码(有注释):

public void toShellSort(int []arr) {
    
    //增量在刚开始的时候为数组长度的一半,以后每次减半,直到增量大于0不成立
    for(int d = (int)(arr.length/2); d > 0; d = (int)(d/2)) {
     
        //首先从每组的第二个数开始,第一次循环是第一组第二个数与第一个数比较,第二次循环是第二组第二个数与第二组第一个数比较
        //进行d次循环后,如果后面还有数
        //第d次循环是第一组第3个数与前面已从小到大排好序的序列比较,第d+1次循环是第二组与第3个数与前面已排好序的序列比较,
        //差不多就是对每组分别进行插入排序
        for(int i = d;i<arr.length;i++) {
                            
            int tempIndex = i;
            while(tempIndex - d >=0 && arr[tempIndex] < arr[tempIndex-d]) {
      
                int temp = arr[tempIndex];
                arr[tempIndex] = arr[tempIndex-d];
                arr[tempIndex-d] = temp;
                tempIndex = tempIndex-d; 
            }        
        }
    }
}

运行效果截图:

在这里插入图片描述
在这里插入图片描述

种一棵树最好的时间是10年前,其次是现在,身为后浪,加油!

目录
相关文章
|
4天前
|
Java
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
|
19天前
|
XML 安全 Java
Java反射机制:解锁代码的无限可能
Java 反射(Reflection)是Java 的特征之一,它允许程序在运行时动态地访问和操作类的信息,包括类的属性、方法和构造函数。 反射机制能够使程序具备更大的灵活性和扩展性
33 5
Java反射机制:解锁代码的无限可能
|
15天前
|
jenkins Java 测试技术
如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例详细说明
本文介绍了如何使用 Jenkins 自动发布 Java 代码,通过一个电商公司后端服务的实际案例,详细说明了从 Jenkins 安装配置到自动构建、测试和部署的全流程。文中还提供了一个 Jenkinsfile 示例,并分享了实践经验,强调了版本控制、自动化测试等关键点的重要性。
48 3
|
20天前
|
存储 安全 Java
系统安全架构的深度解析与实践:Java代码实现
【11月更文挑战第1天】系统安全架构是保护信息系统免受各种威胁和攻击的关键。作为系统架构师,设计一套完善的系统安全架构不仅需要对各种安全威胁有深入理解,还需要熟练掌握各种安全技术和工具。
58 10
|
16天前
|
分布式计算 Java MaxCompute
ODPS MR节点跑graph连通分量计算代码报错java heap space如何解决
任务启动命令:jar -resources odps-graph-connect-family-2.0-SNAPSHOT.jar -classpath ./odps-graph-connect-family-2.0-SNAPSHOT.jar ConnectFamily 若是设置参数该如何设置
|
14天前
|
Java
Java代码解释++i和i++的五个主要区别
本文介绍了前缀递增(++i)和后缀递增(i++)的区别。两者在独立语句中无差异,但在赋值表达式中,i++ 返回原值,++i 返回新值;在复杂表达式中计算顺序不同;在循环中虽结果相同但使用方式有别。最后通过 `Counter` 类模拟了两者的内部实现原理。
Java代码解释++i和i++的五个主要区别
|
22天前
|
搜索推荐 Java 数据库连接
Java|在 IDEA 里自动生成 MyBatis 模板代码
基于 MyBatis 开发的项目,新增数据库表以后,总是需要编写对应的 Entity、Mapper 和 Service 等等 Class 的代码,这些都是重复的工作,我们可以想一些办法来自动生成这些代码。
30 6
|
搜索推荐 算法 Java
插入排序(直接插入排序)java代码实现(注释详细 简单易懂)
插入排序(直接插入排序)java代码实现(注释详细 简单易懂)
132 0
|
Java 机器学习/深度学习 Shell
|
8天前
|
安全 Java 测试技术
Java并行流陷阱:为什么指定线程池可能是个坏主意
本文探讨了Java并行流的使用陷阱,尤其是指定线程池的问题。文章分析了并行流的设计思想,指出了指定线程池的弊端,并提供了使用CompletableFuture等替代方案。同时,介绍了Parallel Collector库在处理阻塞任务时的优势和特点。