当前位置: 首页 > article >正文

数据结构-希尔排序(ShellSort)笔记

看动画理解

【数据结构】八大排序(超详解+附动图+源码)_数据结构排序-CSDN博客

一  基本思想

先选定一个整数gap,把待排序文件中所有记录分成gap个组,所有距离为gap的记录分在同一组内,并对每一组内的元素进行排序。

然后将gap逐渐减小重复上述分组和排序的工作。

当到达gap=1时,所有元素在统一组内排好序。

二  代码实现

import java.util.Arrays; // 导入Arrays类,用于数组操作

public class Main {
    // 主方法,程序的入口点
    public static void main(String[] args) {
        // 初始化一个整型数组,包含一些元素
        int arr[] = {1, 33, 2, 645, 747, 876, -1, -12345, 9, 10};
        
        // 调用sort1方法对数组进行排序
        sort1(arr);
        
        // 使用Arrays.toString方法打印排序后的数组
        System.out.println(Arrays.toString(arr));
    }

    // 定义一个私有静态方法sort1,用于对整型数组进行排序
    private static void sort1(int[] arr) {
        // 外层循环,控制间隔gap的值
        for(int gap = arr.length / 2 ; gap > 0; gap /= 2){
            // 内层循环,从gap开始遍历数组
            for(int i = gap; i < arr.length; i++){
                // 最内层循环,用于比较和交换元素
                for(int j = i - gap; j >= 0; j--){
                    // 如果当前元素比它后面gap位置的元素大,则交换它们
                    if(arr[j] > arr[j + gap]){
                        int temp = arr[j];
                        arr[j] = arr[j + gap];
                        arr[j + gap] = temp;
                    }
                }
            }
        }
    }
}

三  希尔排序的特性总结

希尔排序是对直接插入排序的优化。
当gap > 1时都是预排序,目的是让数组更接近于有序。当gap == 1时,数组已经接近有序的了,这样就会很快。这样整体而言,可以达到优化的效果。
希尔排序的时间复杂度不好计算,因为gap的取值方法很多,导致很难去计算,这里不深究。
时间复杂度O(N^1.5)
空间复杂度O(1)
稳定性:不稳定。


http://www.kler.cn/a/374173.html

相关文章:

  • 【牛客算法】某司面试算法题:设计LRU缓存结构
  • 如何在VMware中安全地恢复已删除的快照?
  • C++ 模板专题 - 静态多态(CRTP)
  • linux之网络子系统- TCP连接建立过程 三次握手四次挥手
  • Linux基础 -- 文件同步之 rsync 命令的使用
  • 如何配置,npm install 是从本地安装依赖
  • 重新架构:从 Redis 到 SQLite 性能提升
  • MySQL基本用法
  • 经典面试题收集(持续更新)
  • 基于人脸识别PCA算法matlab实现及详细步骤讲解
  • 面试题整理 3
  • 我自己的资料整理导引(三):文本格式基础
  • C++算法练习-day29——104.二叉树的最大深度
  • Java基础3-字符串及相关操作
  • 使用正则表达式验证积累
  • springSecurity入门(5.7版本之前)
  • 各种语言的列表推导式与三元?表达式,C++,python,rust,swift,go
  • ubuntu20.04 加固方案-设置重复登录失败后锁定时间限制
  • flutter_vscode常用快捷键
  • Spring Boot租房管理系统:功能实现与优化
  • 美团嵌入式面试题及参考答案(无人机团队)
  • 云-转录组平台升级解锁更多实用交互式功能
  • 【React 的理解】
  • java小白到架构师技术图谱
  • 流媒体转发服务器的应用场景与原理
  • Linux——五种IO模型