希尔排序算法

概念及其介绍:

希尔排序算法是更一种高效的插入排序算法,和普通的插入排序算法相比,希尔排序算法减少了对元素的大小比较和移动元素的次数,从而提高了算法的效率。

过程演示:

按照每4个间隔将数组分成子数组

 

对应比较和交换之后数组变成了这样

 间隔 2 个元素,再次划分整个序列:
 

采用插入排序算法分别对 {14, 27, 35, 42} 和 {19, 10, 33, 44} 进行排序:
 

变成这样之后在进行一次插入排序进行排序就完成了对数组的排序

 

 待排序序列如何进行划分,划分多少次,都会影响到希尔排序算法的执行效率。

希尔排序算法没有固定的划分标准,这里给大家推荐一种常用的方法,套用如下伪代码:

输入 list           //输入待排序序列
interval <- 1    // 初始值为 1
while interval < length(list) / 3:    // length(list) 表示待排序序列的长度
    interval = interval * 3 + 1

经过计算得出的 interval 的值,就是首次划分序列采用的标准。

后续划分整个序列,套用如下公式:

interval = (interval-1)/3

比如说计算第二次划分序列的标准,只需将第一次划分序列时计算得到的 interval 代入公式,求出的新 interval 值就是第二次采用的划分标准。

代码实现:

void the_shall_sort(int arr[],int se)
{
	int temp, i, j;
	int interval = 1;//初始化间隔为1
	//首先计算出进行分割的最大间隔
	//利用公式计算出最大间隔 interval  = interval * 3 -1
	while (interval < se / 3)
	{
		interval = interval * 3 - 1;
	}
	//此时interval 的值已经改变为最大间隔
	//然后此时在进行分割数组,分成相对大小的子数组,并对相对的子数组进行插入排序
	while (interval)
	{
		//让i直接从interval开始,
		for (i = interval; i < se; i++)
		{
			temp = arr[i];
			j = i;//记录下标
			while (j > interval - 1 && arr[j - interval] >= temp)
			{
				arr[j] = arr[j - interval];
				j -= interval;
			}
			if (j != i)
			{
				arr[j] = temp;
			}
		}
		interval = (interval - 1) / 3;
	}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

遇见陌生人了

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值