C语言-希尔排序算法的详解与实现

        希尔排序(Shell Sort)是一种改进的插入排序算法,它通过比较距离较远的元素来提升插入排序的性能。希尔排序将整个数组按一定间隔分割成若干个子数组,并对每个子数组进行插入排序;随着排序的进行,逐渐缩小间隔,直到间隔为1,最终完成排序。希尔排序由Donald Shell于1959年提出,是最早的突破O(n^2)时间复杂度的排序算法之一。

原理

        希尔排序的核心思想是将数组分成若干个间隔为h的子数组,对每个子数组分别进行插入排序。通过逐步缩小间隔h(通常称为增量),最终使整个数组基本有序。最后一次的插入排序实际上是对几乎已经排好序的数组进行最后的微调。

算法步骤

  1. 选择增量序列:选择一个增量序列,逐步缩小增量。
  2. 分组排序:按照当前增量将数组分成若干个子数组。
  3. 插入排序:对每个子数组进行插入排序。
  4. 减小增量:重复上述步骤,缩小增量直到增量为1。

动画演示

以下是希尔排序的动画演示,有助于理解其工作原理:(系统原因无法放动图)

#include <stdio.h>

// 希尔排序函数
void shell_sort(int arr[], int n) {
    int gap, i, j, temp;
    
    // 初始化增量gap为数组长度的一半,逐步减半
    for (gap = n / 2; gap > 0; gap /= 2) {
        // 对每个子数组进行插入排序
        for (i = gap; i < n; i++) {
            temp = arr[i];  // 保存当前需要插入的元素
            // 在子数组内部进行插入排序
            for (j = i; j >= gap && arr[j - gap] > temp; j -= gap) {
                arr[j] = arr[j - gap];  // 元素后移
            }
            arr[j] = temp;  // 插入元素到正确位置
        }
    }
}

// 测试希尔排序的例子
int main() {
    int arr[] = {64, 34, 25, 12, 22, 11, 90};
    int n = sizeof(arr) / sizeof(arr[0]);
    
    printf("排序前的数组:\n");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
    
    // 调用希尔排序函数
    shell_sort(arr, n);
    
    printf("排序后的数组:\n");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
    
    return 0;
}

特性与复杂度分析

  • 时间复杂度:希尔排序的时间复杂度依赖于增量序列的选择,最好情况下为O(n log n),最坏情况下为O(n^2)。
  • 稳定性:希尔排序是不稳定的排序算法,因为在插入排序过程中,可能会改变相同元素的相对顺序。
  • 空间复杂度:希尔排序的空间复杂度为O(1),是一种原地排序算法。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值