首先看一下希尔排序的原理:
原理图解 :
说明:
1.首先希尔排序的核心思想与算法是插入排序,虽然看起来想冒泡排序的两两互换,但请注意实际上并不是两两互换它只是像而已,由此产生了一个非常严重的误区,有的人写着写着就把希尔排序的核心算法写成冒泡排序的两两互换了,实际上他的核心应该是按步长抽数,将抽到的数排序(使用插入排序方法)并按顺序塞回原来的位置,图中每一行为一个循环,而不是从左到右每隔几个步长进行两两互换,千万要注意。
接下来就给大家举个反例:原文链接排序:希尔排序(算法) - 简书 (jianshu.com)
这是此作者写的代码,可以清楚的看到,他犯了一个非常严重的错误就是把希尔排序的核心写成了冒泡排序的两两互换,他的运行结果之所以正确是因为最后用了冒泡排序 ,此种写法不但没有减少运算量还做了大量的无用功,因为无论他之前怎么换最后都需要冒泡排序的大量运算,不光是画蛇添足,惹人生笑,还误导读者,所以一定要多听取别人的意见,遇到错误,虚心请教,然后改正,才是长远之道。
让我们看看下面的评论:
正确演示代码:len是表长,表的第一个位置不存值arr[0]是暂存单元
int ShellSort(int arr[], int len) {
for (int step = len/2; step >=1 ; step=step/2)
{
for (int i = step + 1; i < len; i += step)
{
if (arr[i] < arr[i - step]) {
arr[0] = arr[i];
int j;
for (j = i - step; j>0&&arr[0] < arr[j]; j -= step)
{
arr[j + step] = arr[j];
}
arr[j + step] = arr[0];
}
}
}
return 1;
}
如果有误,欢迎指正。