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] + " ");

}

}

}

相关推荐
南山love3 分钟前
spring-boot项目实现发送qq邮箱
java·服务器·前端
wuqingshun3141596 分钟前
说一下spring的bean的作用域
java·后端·spring
小羊羔heihei6 分钟前
Python编程实战:12道趣味算法题
笔记·python·学习·其他·算法·学习方法·交友
三维重建-光栅投影12 分钟前
PCL之RANSAC实践
算法
weixin_4577600025 分钟前
深入解析 Beam Search:从原理到实践的高效解码算法
python·算法
ulimate_26 分钟前
anygrasp算法:调研与使用
算法
花间相见37 分钟前
【Java基础面试题】—— 核心知识点面试题(含答案):语法+集合+JVM+设计模式+算法
java·jvm·设计模式
会飞De琥珀42 分钟前
java工具类,字符串转时间
java·开发语言
愣头不青1 小时前
96.不同的二叉搜索树
数据结构·算法·leetcode
曹牧1 小时前
JSON 数组的正确使用方式
java·服务器·前端