排序算法学习之希尔排序

    直接插入排序对待排数量较少基本有序的序列,其执行效率是非常高的,希尔排序正是利用了这点,将一个无序的序列拆分成几个子组,然后对几个子组分别进行插入排序。

    注意,这儿的分组并不是简单的{a1,a2,a3,b1,b2,b3,c1,c2,c3}(相同字母为一组),而是进行{a1,b1,c1,a2,b2,c2,a3,b3,c3},因为我们一次分组排序的目的是将各个子组中较小的放到整个序列前面,较大的放到整个序列后面,以形成基本有序然后减少分组数量{a1,b1,a2,b2,a3,b3,a4,b4,a5},继续对每个子组进行插入排序,使序列更加基本有序,直到分组数量等于整个序列长度。

    在实际中,我们用增量increment逐渐减小表示分组数量逐渐减少,而且increment成倍减少, 于是可以写出以下代码:

void ShellSort (int n, int *array)
{
	int i, j;
	int increment;
	for (increment=n/3; increment > 0; increment /= 3)
	{
		for (i=0; i<increment; i++)		/*下面对一组序列进行插入排序*/
		{
			for (j=i+increment; j<n; j+=increment)
			{
				if (array[j] < array[j-increment])
				{
					int key = array[j];
					int k;
					for (k=j-increment; k>=0 && array[k]>key; k -= increment)
					{
						array[k+increment] = array[k];
					}
					array[k+increment] = key;
				}
			}
		}
	}
}

转载于:https://my.oschina.net/xfan001/blog/225460

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值