希尔排序(Shell’s Sort)是插入排序的一种又称“缩小增量排序”(Diminishing Increment Sort),是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因D.L.Shell于1959年提出而得名。
希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。
以上来源于百度百科。
其实,要真正理解希尔排序也不是特别的简单。要想理解希尔排序,就先要知道增量是什么。毕竟他是靠增量来比较排序的,增量就是间隔,从第一个数间隔与多少增量的第二个数比较大小,第二个数要是比前面的数小就交换位置,这么的比较下去,还有要移动的最大次数是(总数量-1)次才不会出错。那么增量是怎么算的,先用总数量除以2,然后增量依次的除2,直到1为止。
现在咱们来看一下代码实现:
结果: