排序算法入门:冒泡、选择、插入排序详解

一、先解答上次的 思考题

图:顶点 0 1 2 3,边:0-1、0-2、1-2、2-3从 0 开始 BFS 典型顺序:0 1 2 3


二、今天学习目标

  1. 了解排序算法的分类与指标
  2. 掌握 冒泡排序
  3. 掌握 选择排序
  4. 掌握 插入排序
  5. 完整可运行代码 + 复杂度总结

三、排序基础概念

  • 稳定排序:相等元素前后顺序不变
  • 时间复杂度:执行快慢
  • 空间复杂度:占用额外内存多少

今天这三个都是:

  • 简单直观
  • 时间复杂度 O(n²)
  • 适合小规模数据

四、1. 冒泡排序(Bubble Sort)

思想:两两比较,大的往后 "冒",每轮冒出一个最大值。

cpp 复制代码
// 冒泡排序
void bubbleSort(int arr[], int n) {
    for (int i = 0; i < n - 1; i++) {
        for (int j = 0; j < n - i - 1; j++) {
            if (arr[j] > arr[j + 1]) {
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

五、2. 选择排序(Selection Sort)

思想:每轮选最小的,放到已排序区间末尾

cpp 复制代码
// 选择排序
void selectionSort(int arr[], int n) {
    for (int i = 0; i < n - 1; i++) {
        int minIdx = i;
        for (int j = i + 1; j < n; j++) {
            if (arr[j] < arr[minIdx])
                minIdx = j;
        }
        // 交换
        int temp = arr[i];
        arr[i] = arr[minIdx];
        arr[minIdx] = temp;
    }
}

六、3. 插入排序(Insertion Sort)

思想:像摸牌一样,把当前数插入前面已经排好的序列里

cpp 复制代码
// 插入排序
void insertionSort(int arr[], int n) {
    for (int i = 1; i < n; i++) {
        int key = arr[i];
        int j = i - 1;
        while (j >= 0 && arr[j] > key) {
            arr[j + 1] = arr[j];
            j--;
        }
        arr[j + 1] = key;
    }
}

七、完整测试代码

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

// 三种排序函数放这里 ......

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

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

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

    // 测试冒泡
    bubbleSort(arr1, n);
    printf("冒泡排序后:");
    printArr(arr1, n);

    return 0;
}

运行结果

cpp 复制代码
原数组:5 2 9 1 5 6
冒泡排序后:1 2 5 5 6 9

八、复杂度对比表

表格

排序 最好 最坏 平均 稳定 原地
冒泡 O(n) O(n²) O(n²) 稳定
选择 O(n²) O(n²) O(n²) 不稳定
插入 O(n) O(n²) O(n²) 稳定

记忆口诀:

  • 冒泡:两两交换
  • 选择:选最小放前面
  • 插入:摸牌插位置

九、今日小练习

对数组 {3, 1, 4, 2, 7, 5}分别用三种排序实现并输出结果。

相关推荐
kkeeper~9 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
2401_868534789 小时前
论企业网络设计
数据结构
wabs66610 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_8769641310 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
嗝o゚11 小时前
CANN GE 算子融合——融合算法与调度策略
算法·昇腾·cann·ge
小江的记录本11 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
Ulyanov12 小时前
用声明式语法重新定义Python桌面UI:QML+PySide6现代开发入门(一)
开发语言·python·算法·ui·系统仿真·雷达电子对抗仿真
数据科学小丫12 小时前
特征工程处理
人工智能·算法·机器学习
z落落13 小时前
C#参数区别
java·算法·c#
c2385614 小时前
vector(下)
数据结构·算法