java 希尔排序

希尔排序(Shell Sort)是一种基于插入排序的排序算法,它通过比较相距一定间隔的元素来工作,然后逐渐缩小这个间隔,直到间隔为1,此时进行一次普通的插入排序。希尔排序的关键在于间隔序列的选择,不同的间隔序列对排序性能有很大影响。

以下是一个简单的希尔排序的Java实现:

复制代码
public class ShellSort {  
  
    // 希尔排序算法  
    public static void shellSort(int[] array) {  
        int n = array.length;  
  
        // 初始间隔为数组长度的一半,之后每次减半  
        for (int gap = n / 2; gap > 0; gap /= 2) {  
            // 从gap位置开始,对每个子数组进行插入排序  
            for (int i = gap; i < n; i++) {  
                int temp = array[i];  
                int j;  
  
                // 对当前间隔的子数组进行插入排序  
                for (j = i; j >= gap && array[j - gap] > temp; j -= gap) {  
                    array[j] = array[j - gap];  
                }  
  
                array[j] = temp;  
            }  
        }  
    }  
  
    // 打印数组  
    public static void printArray(int[] array) {  
        for (int value : array) {  
            System.out.print(value + " ");  
        }  
        System.out.println();  
    }  
  
    // 主方法  
    public static void main(String[] args) {  
        int[] array = {12, 34, 54, 2, 3};  
        System.out.println("排序前的数组:");  
        printArray(array);  
  
        shellSort(array);  
  
        System.out.println("排序后的数组:");  
        printArray(array);  
    }  
}

代码解释

  1. 间隔序列:初始间隔序列为数组长度的一半,然后每次减半,直到间隔为1。
  2. 外层循环:控制间隔大小的变化。
  3. 内层循环:从当前间隔位置开始,对每个子数组进行插入排序。
  4. 内部插入排序:在当前间隔下,进行插入排序,调整元素位置。

复杂度

希尔排序的时间复杂度取决于间隔序列的选择,通常会比简单的插入排序快很多,但最坏情况下仍可能达到O(n^2)。然而,在实际应用中,希尔排序通常表现得相当好,特别是在处理中等规模的数据集时。

注意事项

  • 间隔序列的选择对希尔排序的性能有很大影响。上述实现使用的是最简单的间隔序列(每次减半),但在实际应用中,还有更复杂的间隔序列(如Hibbard增量序列、Sedgewick增量序列等)可能提供更好的性能。
  • 希尔排序是就地排序算法,不需要额外的存储空间。
相关推荐
电鱼智能的电小鱼3 小时前
基于电鱼 AI 工控机的智慧工地视频智能分析方案——边缘端AI检测,实现无人值守下的实时安全预警
网络·人工智能·嵌入式硬件·算法·安全·音视频
孫治AllenSun4 小时前
【算法】图相关算法和递归
windows·python·算法
格图素书5 小时前
数学建模算法案例精讲500篇-【数学建模】DBSCAN聚类算法
算法·数据挖掘·聚类
DashVector6 小时前
向量检索服务 DashVector产品计费
数据库·数据仓库·人工智能·算法·向量检索
AI纪元故事会6 小时前
【计算机视觉目标检测算法对比:R-CNN、YOLO与SSD全面解析】
人工智能·算法·目标检测·计算机视觉
夏鹏今天学习了吗6 小时前
【LeetCode热题100(59/100)】分割回文串
算法·leetcode·深度优先
卡提西亚6 小时前
C++笔记-10-循环语句
c++·笔记·算法
还是码字踏实6 小时前
基础数据结构之数组的双指针技巧之对撞指针(两端向中间):三数之和(LeetCode 15 中等题)
数据结构·算法·leetcode·双指针·对撞指针
Coovally AI模型快速验证8 小时前
当视觉语言模型接收到相互矛盾的信息时,它会相信哪个信号?
人工智能·深度学习·算法·机器学习·目标跟踪·语言模型
电院工程师8 小时前
SIMON64/128算法Verilog流水线实现(附Python实现)
python·嵌入式硬件·算法·密码学