java实现希尔排序

public class ShellSort {

public static void sort(int[] arr) {

int n = arr.length;

int gap = n / 2;

while (gap > 0) {

for (int i = gap; i < n; i++) {

int temp = arr[i];

int j = i;

while (j >= gap && arr[j - gap] > temp) {

arr[j] = arr[j - gap];

j -= gap;

}

arr[j] = temp;

}

gap /= 2;

}

}

public static void main(String[] args) {

int[] arr = {8, 2, 7, 3, 1, 5, 6, 4};

sort(arr);

for (int i = 0; i < arr.length; i++) {

System.out.print(arr[i] + " ");

}

}

}

相关推荐
Tisfy7 小时前
LeetCode 3637.三段式数组 I:一次遍历(三种实现)
算法·leetcode·题解·模拟·数组·遍历·moines
笃行客从不躺平7 小时前
Token 复习
java·分布式·spring cloud
遨游xyz8 小时前
数据结构-哈希表
算法·哈希算法
Albert Edison8 小时前
【Python】函数
java·linux·python·pip
dyyx1118 小时前
C++中的过滤器模式
开发语言·c++·算法
2301_818732068 小时前
项目启动报错,错误指向xml 已解决
xml·java·数据库·后端·springboot
lrh1228008 小时前
详解决策树算法:分类任务核心原理、形成流程与剪枝优化
算法·决策树·机器学习
期末考复习中,蓝桥杯都没时间学了8 小时前
力扣刷题15
算法·leetcode·职场和发展
码农阿豪8 小时前
Oracle 到金仓数据库迁移实战:一次真正“落地”的国产替代之旅
java·数据库·oracle
2301_817497338 小时前
C++中的装饰器模式高级应用
开发语言·c++·算法