快速排序与希尔排序实战解析

一、今天学习目标

  1. 希尔排序(插入排序升级版)
  2. 快速排序(最常用、面试必考)
  3. 完整可运行代码
  4. 复杂度对比

二、希尔排序(Shell Sort)

思想:

  • 分组做插入排序
  • 逐步缩小增量(gap)
  • 最后 gap=1 时就是普通插入排序,但数组已经基本有序,非常快
cpp 复制代码
// 希尔排序
void shellSort(int arr[], int n) {
    for (int gap = n / 2; gap > 0; gap /= 2) {
        for (int i = gap; i < n; i++) {
            int temp = arr[i];
            int j;
            for (j = i; j >= gap && arr[j - gap] > temp; j -= gap) {
                arr[j] = arr[j - gap];
            }
            arr[j] = temp;
        }
    }
}

三、快速排序(Quick Sort)

思想:

  • 选一个基准 pivot
  • 小的放左边,大的放右边
  • 递归左右两部分

平均复杂度 O(n log n),实际最快。

cpp 复制代码
// 交换
void swap(int *a, int *b) {
    int t = *a;
    *a = *b;
    *b = t;
}

// 划分函数
int partition(int arr[], int low, int high) {
    int pivot = arr[high];
    int i = low - 1;

    for (int j = low; j < high; j++) {
        if (arr[j] < pivot) {
            i++;
            swap(&arr[i], &arr[j]);
        }
    }
    swap(&arr[i + 1], &arr[high]);
    return i + 1;
}

// 快排递归
void quickSort(int arr[], int low, int high) {
    if (low < high) {
        int pi = partition(arr, low, high);
        quickSort(arr, low, pi - 1);
        quickSort(arr, pi + 1, high);
    }
}

四、完整测试代码

cpp 复制代码
#include <stdio.h>

// swap、shellSort、quickSort、partition 都放这里

void printArr(int arr[], int n) {
    for (int i = 0; i < n; i++)
        printf("%d ", arr[i]);
    printf("\n");
}

int main() {
    int arr1[] = {9, 3, 7, 1, 5, 2, 8, 4, 6};
    int n = sizeof(arr1) / sizeof(arr1[0]);

    printf("原数组:");
    printArr(arr1, n);

    shellSort(arr1, n);
    printf("希尔排序后:");
    printArr(arr1, n);

    int arr2[] = {9, 3, 7, 1, 5, 2, 8, 4, 6};
    quickSort(arr2, 0, n - 1);
    printf("快速排序后:");
    printArr(arr2, n);

    return 0;
}

运行结果:

cpp 复制代码
原数组:9 3 7 1 5 2 8 4 6
希尔排序后:1 2 3 4 5 6 7 8 9
快速排序后:1 2 3 4 5 6 7 8 9

五、复杂度对比

表格

算法 时间复杂度 稳定性
希尔 O(n log n) ~ O(n²) 不稳定
快排 O (n log n) 平均 不稳定

六、今日小练习

对数组 {6, 1, 8, 3, 5, 2, 7, 4}分别使用希尔排序、快速排序并输出结果。

相关推荐
QiLinkOS12 分钟前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法
如此这般英俊37 分钟前
手撕Claude Code—第一章 agent-loop
数据结构·人工智能·语言模型·自然语言处理
小白兔奶糖ovo1 小时前
【Leetcode】231. 2的幂
linux·算法·leetcode
xiaoxiaoxiaolll1 小时前
《Light: Science & Applications》合并BIC实现80倍阈值单模运行:超紧凑光子晶体激光器新突破
人工智能·算法·机器学习
Peter·Pan爱编程1 小时前
14. Lambda 表达式:随手可写的函数对象
c++·算法·ai编程
-To be number.wan1 小时前
算法日记 | 暴力枚举
学习·算法
s_w.h1 小时前
【 linux 】动静态库的制作
linux·运维·服务器·算法·bash
过期动态2 小时前
【LeetCode 热题 100】接雨水
java·数据结构·算法·leetcode·职场和发展
春日见2 小时前
5分钟入门强化学习之动态规划算法与实现
大数据·人工智能·python·算法·机器学习·计算机视觉
scx_link2 小时前
线性回归的总结:
算法·机器学习·线性回归