1)将n个元素的数组分为n/2个数据序列,第一个数据和第n/2+1个数据为一对
2)一次循环使每一个序列对应排好顺序
3)然后,再变为n/4个序列,再次排序
4)不断重复上述过程
例如如下数据排序
初始数据 127 118 105 101 112 100
一次排序 101 112 100 127 118 105
二次排序 100 101 105 112 118 127
第一次排序 首先数组分为6/2=3 3个元素一组
第二次排序 6/4=1(取整数) 每个逐个数据比较,采用插入算法进行
public class ShellSort { public static int count = 0; public static void main(String[] args) { int[] data = new int[] { 5, 3, 6, 2 }; print(data); shellSort(data); print(data); } public static void shellSort(int[] data) { // 计算出最大的h值 int h = 1; System.out.println(data.length / 3); while (h <= data.length / 3) { h = h * 3 + 1; } while (h > 0) { for (int i = h; i < data.length; i += h) { if (data[i] < data[i - h]) { int tmp = data[i]; int j = i - h; while (j >= 0 && data[j] > tmp) { data[j + h] = data[j]; j -= h; } data[j + h] = tmp; print(data); } } // 计算出下一个h值 h = (h - 1) / 3; } } public static void print(int[] data) { for (int i = 0; i < data.length; i++) { System.out.print(data[i] + "\t"); } System.out.println(); } }