Java 8大排序算法之希尔排序

希尔排序(Shell’s Sort)是插入排序的一种又称“缩小增量排序”(Diminishing Increment Sort),是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因D.L.Shell于1959年提出而得名。
希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。

Java 8大排序算法之希尔排序_第1张图片
以上来源于百度百科。

其实,要真正理解希尔排序也不是特别的简单。要想理解希尔排序,就先要知道增量是什么。毕竟他是靠增量来比较排序的,增量就是间隔,从第一个数间隔与多少增量的第二个数比较大小,第二个数要是比前面的数小就交换位置,这么的比较下去,还有要移动的最大次数是(总数量-1)次才不会出错。那么增量是怎么算的,先用总数量除以2,然后增量依次的除2,直到1为止。

现在咱们来看一下代码实现:

Java 8大排序算法之希尔排序_第2张图片

结果:
Java 8大排序算法之希尔排序_第3张图片

你可能感兴趣的:(Java 8大排序算法之希尔排序)