希尔排序
希尔排序的思想是使数组中任意间隔为h的元素都是有序的
希尔排序轨迹:间隔为 5,3, 1
排序前
第一次间隔为5,得到的子序列为:
(49, 13) (38, 27) (65, 49) (97, 55) (76, 4)
对子序列进行插入排序,得到:
第二次间隔为3,得到的子序列为:
(13, 55, 38, 76) (27, 4, 65) (49, 49, 97)
对子序列进程插入排序,得到:
最后一次间隔为1,得到的子序列就是第二次排序后的序列,对该序列进行插入排序
代码实现
回顾一下插入排序的代码实现
插入排序
遍历数组,将数据插入到合适到位置
第一次:只有一个数,那么它一定在它最合适的位置
第二次:比较第二个数与第一个数的大小,如果第二个数小于第一个数,交换他们位置
第三次:比较第三个数与前两个数的大小,并按照比较结果交换它们位置
直到数组遍历完
而希尔排序中最后一步一定是对整个序列进行插入排序,故可以参照插入排序的实现逻辑
希尔排序java实现