C++深入浅出讲解希尔排序算法的实现

 更新时间:2022年05月18日 10:41:34   作者:安然无虞  
希尔排序是希尔(Donald Shell)于1959年提出的一种排序算法。希尔排序也是一种插入排序,它是简单插入排序经过改进之后的一个更高效的版本,也称为缩小增量排序,同时该算法是冲破O(n2)的第一批算法之一。本文会以图解的方式详细介绍希尔排序的基本思想及其代码实现

插入排序分为两种:直接插入排序&希尔排序

希尔排序

1.基本思想

希尔排序是在直接插入排序基础上的优化,属于非常牛掰的一个排序。

核心思想:

  • 先进行预排序,让数组接近有序;
  • 直接插入排序

预排序

预排序步骤:

分组排,假设gap==3,间隔为gap的为一组,然后分别使用插入排序的思想对这gap组数据进行排序

多组间隔为gap的预排序,gap由大变小,gap越大,大的数可以越快的到后面,小的数可以越快得到前面,gap越大,预排完越不接近有序,gap越小,预排完越接近有序,gap为1时就是直接插入排序

动图演示:

预排序代码:

		for (int i = 0; i < gap; i++)//有gap组需要排
		{
			for (int j = i; j < n - gap; j += gap)//内层循环,先排红,再排绿,最后排蓝
			//注意内层循环的写法
			{
			//跟直接插入排序很像,不同的是需要使用gap
				int end = j;
				int tmp = a[end + gap];
				while (end >= 0)
				{
					if (a[end] > tmp)
					{
						a[end + gap] = a[end];
						end -= gap;
					}
					else
					{
						break;
					}
				}
				a[end + gap] = tmp;
			}
		}

这是最初的写法,其实这个代码是可以优化的:

//预排序优化
		for (int i = 0; i < n - gap; i++)
		//把间隔为gap的多组数据同时排
		//当到n-gap-1的位置就终止了
		{
			int end = i;
			int tmp = a[end + gap];
			while (end >= 0)
			{
				if (a[end] > tmp)
				{
					a[end + gap] = a[end];
					end -= gap;
				}
				else
				{
					break;
				}
			}
			a[end + gap] = tmp;
		}

2.算法实现

//希尔排序
void ShellSort(int* a, int n)
{
	//一开始初始化gap为n
	int gap = n;
	while (gap > 1)//gap大于1都是预排序,gap==1时为直接插入排序
	{
		//为保证gap最终结果为1,可以gap/=2,也可以是gap=gap/3+1;
		gap /= 2;
		//预排序优化
		for (int i = 0; i < n - gap; i++)
		//把间隔为gap的多组数据同时排
		//当到n-gap-1的位置就终止了
		{
			int end = i;
			int tmp = a[end + gap];
			while (end >= 0)
			{
				if (a[end] > tmp)
				{
					a[end + gap] = a[end];
					end -= gap;
				}
				else
				{
					break;
				}
			}
			a[end + gap] = tmp;
		}
	}
}

完整代码:

3.时间复杂度

希尔排序的时间复杂度是:O(N*logN)

到此这篇关于C++深入浅出讲解希尔排序算法的实现的文章就介绍到这了,更多相关C++希尔排序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Ubuntu配置sublime text 3的c编译环境的具体步骤

    Ubuntu配置sublime text 3的c编译环境的具体步骤

    下面小编就为大家带来一篇Ubuntu配置sublime text 3的c编译环境的具体步骤。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03
  • C++标准库中sstream与strstream的区别详细解析

    C++标准库中sstream与strstream的区别详细解析

    以下是对C++标准库中sstream与strstream的区别进行了详细的分析介绍,需要的朋友可以过来参考下
    2013-09-09
  • C++11利用原子操作实现自旋锁

    C++11利用原子操作实现自旋锁

    C++自旋锁是一种低层次的同步原语,用于保护共享资源的访问,这篇文章主要为大家介绍了如何利用原子操作实现自旋锁,感兴趣的小伙伴可以了解下
    2023-09-09
  • QString的常用方法(小结)

    QString的常用方法(小结)

    这篇文章主要介绍了QString的常用方法(小结),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • C语言中强制类型转换的常见方法

    C语言中强制类型转换的常见方法

    强制类型转换是一种将一个数据类型转换为另一个数据类型的方法,这篇文章主要为大家整理了C语言中强制类型转换的方法,需要的可以参考一下
    2023-05-05
  • C++面试八股文之STL标准模板库使用详解

    C++面试八股文之STL标准模板库使用详解

    这篇文章主要为大家介绍了C++面试八股文之STL标准模板库使用详解,<BR>有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • C语言 语义陷阱超详细梳理总结

    C语言 语义陷阱超详细梳理总结

    这篇文章主要介绍了C语言常见的一些语义陷阱,梳理的比较全面,对我们做开发的过程中有一定帮助,感兴趣的朋友快来看看吧
    2022-03-03
  • c++实现单纯形法现行规划问题的求解(推荐)

    c++实现单纯形法现行规划问题的求解(推荐)

    这篇文章主要介绍了c++实现单纯形法现行规划问题的求解,本文针对问题通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-04-04
  • C++实现归并排序

    C++实现归并排序

    这篇文章主要为大家详细介绍了C++实现归并排序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • C++右值引用问题解决

    C++右值引用问题解决

    本文主要介绍了C++右值引用问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06

最新评论