十大排序——7.希尔排序

下面我们来看一下希尔排序

目录

1.介绍

2.代码实现

3.总结与思考


1.介绍

希尔排序是插入排序的一种优化,可以理解为是一种分组的插入排序

希尔排序的要点:

简单来说,就是分组实现插入,每组元素的间隙称为gap,**一开始给你一个无序数组,然后我们以gap为间隙对这个数组进行分组,然后在每组内对数据进行排序,这就实现了每组的数据有序性。然后,我们减小gap的值,然后再分组,再对每组内的数据进行排序,直到gap为1完成排序。**希尔排序是对插入排序的优化,可以让元素跟快的交换到最终位置。

举例说明:

如下图所示,一开始是无序数组,8个元素,然后我们分为4组,gap值为4,序号1的图;然后在这四组内进行排序,实现了组内有序,序号2的图;然后我们再分组,分为6组,gap值为2,序号3的图;然后再排序,再次实现了组内有序,序号4的图;依次类推,直到gap值为1,数组就排好序了。

2.代码实现

下面看一下代码的实现:

java 复制代码
package Sorts;

import java.util.Arrays;
//希尔排序
public class XiErSort {
    public static void main(String[] args) {
        int [] arr = new int []{5,9,2,7,3,1,10};
        xiEr(arr);
        System.out.println(Arrays.toString(arr));
    }
    public static void xiEr(int arr[]){
        for (int gap = arr.length/2; gap >0 ; gap /=2) {
            for (int low = gap; low <arr.length ; low++) {
                int t = arr[low];
                int i = low - gap;
                //自右向左找插入位置,如果比待插入的元素大,则不断右移,空出插入位置
                while (i >= 0 && t < arr[i]){
                    arr[i+gap] = arr[i];
                    i-=gap;
                }
                //找到插入位置
                if(i != low-gap){
                    arr[i+gap] = t;
                }
            }
        }
    }
}

3.总结与思考

不算难,就是插入排序的一个优化,结合代码来看很好理解的。

相关推荐
stolentime25 分钟前
CF2066D1 Club of Young Aircraft Builders (easy version)题解
c++·算法·动态规划·组合数学
Dillon Dong27 分钟前
【风电控制】高低穿现场失败的原因分析——算法简单但工程复杂
算法·变流器·风电控制·dfig
小欣加油38 分钟前
leetcode41 缺失的第一个正数
数据结构·c++·算法·leetcode
I Promise3441 分钟前
智驾APA_HPA可行驶区域检测算法工程师面试问题整理可参考
算法·面试·职场和发展
智者知已应修善业1 小时前
【51单片机按键控制1分钟正计时倒计时暂停复位】2024-1-2
c++·经验分享·笔记·算法·51单片机
weixin_468466851 小时前
UNet 模型结构从零搭建与实战解析
人工智能·深度学习·算法·机器学习·ai·unet
努力努力再努力wz1 小时前
【Qt入门系列】一文掌握 Qt 常用显示类控件:QLCDNumber、QProgressBar 与 QCalendarWidget
c语言·开发语言·数据结构·数据库·c++·git·qt
Useasy_JIJIANYUN1 小时前
合作快讯:极简云呼叫中心(Useasy)正式上架Zoho全球应用市场!
算法
isyoungboy1 小时前
Delaunay 拓扑图割法一种特征抽稀算法
算法
Shan12052 小时前
算法案例精讲:连接所有点的最小费用
算法