十大经典排序算法之希尔排序。

希尔排序 (Shell Sort)

​ 希尔排序(Shell Sort)是一种改进的插入排序算法,它的基本思想是通过将待排序列表分割成若干个子列表,对每个子列表进行插入排序,然后逐步缩小子列表的间隔,直到间隔为1,最终完成整个列表的排序。

希尔排序的步骤如下:

  1. 选择一个间隔序列(Increment Sequence),即一系列增量值(例如,[n/2, n/4, n/8, ..., 1]),其中 n 是列表的长度。
  2. 根据选择的增量值,将列表分割成若干个子列表,每个子列表包含间隔值指定的元素。
  3. 对每个子列表分别进行插入排序,即将子列表中的元素按照插入排序的方式进行排序。
  4. 重复以上步骤,逐步缩小增量值,直到增量值为1,完成最后一次插入排序,此时整个列表已经有序。
  5. 时间复杂度取决于所选择的增量序列,最坏情况下的时间复杂度为 O(n^2),但是对于大多数增量序列,希尔排序的时间复杂度通常在 O(n^1.3) 左右。

接下来我们给出示例代码

c 复制代码
void shell_sort(int *array, int array_num)
{
	int				group;
	int				i;
	int				j;
	int				cur_data;

	printf("shell sort\n");

	for (group=array_num/2; group>0; group=group/2)
	{
		for (i = group; i < array_num; i++)
		{
			j = i;
			cur_data = array[i];
			while ( j-group>=0 && cur_data<array[j-group] )
			{
				array[j] = array[j - group];
				j = j - group;
			}
			array[j] = cur_data;
		}
	}
}
相关推荐
老黄编程10 小时前
视觉SLAM十四讲解读-(v2.p84)李代数求导
算法·slam·李群李代数·视觉slam十四讲
LYFlied10 小时前
【每日算法】131. 分割回文串
前端·数据结构·算法·leetcode·面试·职场和发展
夏乌_Wx10 小时前
练题100天——DAY30:下一个更大的元素+键盘行
数据结构·算法
长安er10 小时前
LeetCode 300/152/416/32 动态规划进阶题型总结(最长递增子序列→最长有效括号)
数据结构·算法·leetcode·动态规划·剪枝
天赐学c语言10 小时前
12.18 - 有效的括号 && C语言中static的作用
数据结构·c++·算法·leecode
季远迩10 小时前
LeetCode 热题 100 Python3易懂题解(更新中)
算法·leetcode·哈希算法
CoovallyAIHub10 小时前
从“模仿”到“进化”!华科&小米开源MindDrive:在线强化学习重塑「语言-动作」闭环驾驶
深度学习·算法·计算机视觉
xie_pin_an10 小时前
C 语言排序算法全解析:从原理到实战,附性能对比
c语言·算法·排序算法
CoovallyAIHub10 小时前
SAM 真的开始「分割一切」,从图像到声音,Meta 开源 SAM Audio
深度学习·算法·计算机视觉
三斗米10 小时前
从思维链到思维树:一步步解锁大语言模型的推理能力
算法