关于希尔排序的一大坑,与冒泡排序有关千万注意

首先看一下希尔排序的原理:

 

 

原理图解 :

 

说明:

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;
	
}

 如果有误,欢迎指正。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值