


package com.atguigu.sort;
import java.util.Arrays;
public class ShellSort {
public static void main(String[] args) {
int[] arr = {8,9,1,7,2,3,5,4,6,0};
shellSort(arr);
}
// 希尔排序(交换法)
public static void shellSort(int[] arr){
int temp = 0;
for (int gap = arr.length/2; gap > 0; gap = gap/2){ // 步长变化
// 第一轮:将10个数分gap组
for (int i = gap; i < arr.length; i++){ // gap 到 length-1 位置的元素,是需要处理的元素
// 遍历各组中所有的元素(共gap组,每组有元素),步长为gap
for (int j = i-gap; j >= 0; j -= gap){
// 如果当前元素大于加上步长后的哪个元素,说明交换
if (arr[j] > arr[j+gap]){
temp = arr[j];
arr[j] = arr[j+gap];
arr[j+gap]=temp;
}
}
}
System.out.println(Arrays.toString(arr));
}
}
}