希尔排序详解及代码讲解

希尔排序是插入排序的一种高效改进版本,也称为"缩小增量排序"。它通过将原始数组分成多个子序列来提高插入排序的效率。

算法思想

希尔排序的基本思想是:

  1. 将数组按照一定的间隔(gap)分成若干子序列

  2. 对每个子序列进行插入排序

  3. 逐渐缩小间隔,重复上述过程

  4. 当间隔为1时,进行最后一次插入排序,此时数组已经基本有序,插入排序效率很高

代码:

复制代码
void ShellSort(int* num, int n)
{
    int gap = n;  // 初始化间隔为数组长度
    while (gap > 1)  // 当间隔大于1时继续排序
    {
        // 计算新的间隔
        gap = gap / 3 + 1;
        
        // 对每个子序列进行插入排序
        for (int i = 0; i < n - gap; i++)
        {
            int end = i;
            int temp = num[end + gap];  // 保存当前待插入元素
            
            // 插入排序过程
            while (end >= 0)
            {
                if (num[end] > temp)  // 如果前一个元素大于待插入元素
                {
                    num[end + gap] = num[end];  // 向后移动元素
                    end -= gap;  // 向前比较
                }
                else
                {
                    break;  // 找到合适位置,退出循环
                }
            }
            num[end + gap] = temp;  // 插入元素到正确位置
        }
    }
}

详细步骤说明

  1. 初始化间隔(gap):

    • 初始间隔设为数组长度n

    • 使用gap = gap / 3 + 1来计算新的间隔,这是一种常见的间隔序列计算方式

  2. 外层循环:

    • 当gap > 1时继续排序

    • 每次循环后gap会缩小,直到最后gap=1

  3. 中间层循环:

    • for (int i = 0; i < n - gap; i++)控制每次处理的起始位置

    • 这个循环实际上是对各个子序列进行交替处理,而不是完整处理一个子序列后再处理下一个

  4. 内层循环(插入排序):

    • 保存当前元素num[end + gap]到temp

    • 将temp与前面间隔gap的元素比较

    • 如果前面的元素更大,则向后移动

    • 直到找到合适的位置插入temp

相关推荐
灵感__idea1 天前
Hello 算法:众里寻她千“百度”
前端·javascript·算法
Wect2 天前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP2 天前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱2 天前
单调栈:从模板到实战
javascript·后端·算法
是希燃亚3 天前
📚 十大经典排序算法 C语言笔记(一看就会版)
排序算法
CoovallyAIHub3 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub3 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub3 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub3 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub3 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉