希尔排序也是一种插入排序,它是简单插入排序经过改进之后的一个更高效的版本,也称为缩小增量排序,希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,再经过一次插入排序,算法便终止。

- public class ssort {
- public static void main(String[] args) {
- int[] array = new int[]{1, 4, 2, 7, 9, 8, 3, 6, 0, 5};
- sort(array);
- System.out.println(Arrays.toString(array));
- }
-
- public static void sort(int[] array) {
- int len = array.length;
- for (int gap = len / 2; gap > 0; gap /= 2) {
- //gap = 5 ,2 ,1,插入排序从gap开始遍历而不是从0开始
- for (int i = gap; i < len; i++) {
- int temp = array[i];
- for (int j = i; j - gap >= 0; j -= gap) {
- if (array[j - gap] > array[j]) {
- //右移
- array[j] = array[j - gap];
- array[j - gap] = temp;
- } else {
- break;
- }
- }
- }
- }
- }
- }