希尔排序(ShellSort)详解

希尔排序的底层是插入排序,

不了解插入排序的友友可以先看我下面这篇文章:

插入排序详解-CSDN博客

思路

就整体而言,希尔排序不过是多用了几次插入排序,

预排序→插入排序,

预排序的作用是让数组元素更接近于有序,

以缩短最后插入排序的时间,

达到优化插入排序的效果。

预排序走的也是插入排序,

但是元素与元素之间的间隔不是1,而是gap(我们自己定义的,有计算公式),

而且gap会越来越小,

直至gap等于1,

就是正统的插入排序

画个粗略的图让大家理解一下:

下图有11个元素,

gap1=11/3+1=4,

gap2=gap1/3+1=4/3+1=2,

gap3=gap2/3+1=2/3+1=1.

建议大家看图时配合代码一起食用。

代码

cpp 复制代码
void ShellSort(int* arr, int n)
{
	int gap = n;
	while (gap>1)
	{
		gap = gap / 3 + 1;//这条式子可以保证gap最后一定为1,走一遍插入排序

//i<n-gap,即i的最大值为n - gap - 1,保证数组不越界,因为tmep最大取到了arr[end + gap]
		for (int i = 0; i < n - gap; i++)
		{
//下面的框架和思想基本与插入排序一致
			int end = i;
			int temp = arr[end + gap];
			while (end >= 0)
			{
				if (temp < arr[end])
				{
					arr[end + gap] = arr[end];
					end -= gap;
				}
				else
				{
					break;
				}
			}
			arr[end + gap] = temp;
		}
	}
}
相关推荐
sjsjs116 分钟前
力扣3558. 给边赋权值的方案数 I
算法·leetcode·职场和发展
hujinyuan201607 分钟前
2025年12月中国电子学会青少年机器人技术等级考试试卷(四级) 真题+答案
算法·机器人
啦啦啦啦啦zzzz10 分钟前
算法总结(双指针)
c++·算法·双指针
花间相见21 分钟前
【LeetCode01】—— 无重复字符的最长子串:滑动窗口经典题详解
python·算法·leetcode
wabs66626 分钟前
关于动态规划【力扣96.不同的二叉搜索树的递推公式怎么理解?】
算法·动态规划
Yiyaoshujuku32 分钟前
化合物数据集API接口(数据结构及样例)
java·网络·数据结构
QiLinkOS33 分钟前
极客与商业思维的融合实践(1)
c语言·数据库·c++·人工智能·算法·开源协议
fu的博客36 分钟前
【数据结构16】图:基于邻接矩阵、邻接表实现DFS/BFS
数据结构·算法
阿正的梦工坊42 分钟前
【Rust】17-Send、Sync 与并发安全抽象
算法·安全·rust
plainGeekDev1 小时前
算法刷题笔记:一维DP没那么难,状态想清楚就赢了一半
java·算法·面试