来源百度百科:html
希尔排序(Shell's Sort)是插入排序的一种又称“缩小增量排序”(Diminishing Increment Sort),是直接插入排序算法的一种更高效的改进版本。希尔排序是非稳定排序算法。该方法因D.L.Shell于1959年提出而得名。
从上面咱们很容易看出来,它是插入排序的高级版java
回顾一下插入排序:算法
将数据插入到已有序的数列中shell
既然希尔排序是插入排序的高级版,那它作了哪些优化呢??让咱们来看看:数组
从直观上看希尔排序:微信
那么,上面那里说了将一个序列分红好几个序列,那么到底怎么分呢?好比有10个元素的序列,分红几个才合适?每次缩减又是多少呢?优化
从专业的角度上讲,将一个序列分红好几个序列,用一个数来表示:那个数称为增量。显然的是,增量是不断递减的(直到增量为1)spa
每每的:若是一个数列有10个元素,咱们第一趟的增量是5,第二趟的增量是2,第三趟的增量是1。若是一个数列有18个严肃,咱们第一趟的增量是9,第二趟的增量是4,第三趟的增量是2,第四趟的增量是1.net
很明显咱们能够用一个序列来表示增量:{n/2,(n/2)/2...1}
,每次增量都/2
code
如今咱们有一个数组,该数组有6个元素
int[] arrays = {2, 5, 1, 3, 4, 6};
排序前:
{2,3}
,{5,4}
,{1,6}
第一趟排序:
对三个数组分别进行插入排序,所以咱们三个数组获得的结果为{2,3}
,{4,5}
,{1,6}
{2, 4, 1, 3, 5, 6}
第二趟排序:
{2, 4, 1, 3, 5, 6}
当作一个数组(从宏观上是有序的了),对其进行插入排序,直至有序 可能我举的例子不够好(没看到很好的效果),咱们来看看网上的图片,加深一下希尔排序的过程:
PS:图片来源网上(侵删)
public static void shellSort(int[] arrays) { //增量每次都/2 for (int step = arrays.length / 2; step > 0; step /= 2) { //从增量那组开始进行插入排序,直至完毕 for (int i = step; i < arrays.length; i++) { int j = i; int temp = arrays[j]; // j - step 就是表明与它同组隔壁的元素 while (j - step >= 0 && arrays[j - step] > temp) { arrays[j] = arrays[j - step]; j = j - step; } arrays[j] = temp; } } }
咱们发现希尔排序代码其实很是简单(相比对堆排序),理解起来也不难,就用增量来将数组进行分隔,直到增量为1。底层干的仍是插入排序干的活~
参考资料:
若是文章有错的地方欢迎指正,你们互相交流。习惯在微信看技术文章,想要获取更多的Java资源的同窗,能够 关注微信公众号:Java3y