嵌入式 - 数据结构与算法:(1-10)排序算法 - 冒泡排序(Bubble Sort)

上一篇 下一篇
队列

目 录


1)冒泡排序(Bubble Sort)

冒泡排序通过 多次遍历数组,比较相邻元素 ,若顺序错误(如升序情况下,前 > 后)则交换。每一轮遍历会 将当前未排序部分中的最大值 "冒泡" 到末尾。重复此过程,直到整个数组有序。特点是:简单直观、稳定、原地排序。

1.1)算法步骤

  1. 从索引 0 开始,比较 arr[i]arr[i+1]
  2. 升序要求下,如果 arr[i] > arr[i+1],交换两者;
  3. 继续向后比较,直到倒数第二个元素;
  4. 第一轮结束后,最大元素已在最后;
  5. 对前 n-1 个元素重复上述过程;
  6. 若某轮未发生任何交换,说明数组已有序,可提前终止(优化)。

1.2)时间与空间复杂度

情况 时间复杂度
最好(已有序) O(n)(需优化)
平均 O(n²)
最坏(逆序) O(n²)
  • 空间复杂度:O(1)(原地排序)
  • 稳定性:✔️ 稳定(相等元素不交换)

1.3)C 语言代码示例

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

/**
 * @brief:		bubble_sort ------ 冒泡排序函数(升序)
 * @note:		n - 输入数组长度
 */
void bubble_sort(int arr[], int n) 
{
    for (int i=0; i<n-1; i++) 
    {
        int swapped = 0; // 优化标志:本轮是否发生交换

        // 每轮将最大元素移到末尾
        for (int j=0; j<n-1-i; j++) 
        {
            if (arr[j] > arr[j+1]) 
            {
                // 交换 arr[j] 和 arr[j+1]
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
                swapped = 1;
            }
        }

        // 如果本轮没有交换,说明已有序,提前退出
        if (!swapped)
            break;
    }
}

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

/* 主函数:测试冒泡排序 */
int main() 
{
    int arr[] = {64, 34, 25, 12, 22, 11, 90};
    int n = sizeof(arr) / sizeof(arr[0]);

    printf("原始数组: ");
    print_array(arr, n);

    bubble_sort(arr, n);

    printf("排序后数组: ");
    print_array(arr, n);

    return 0;
}

运行结果如下:

复制代码
原始数组: 64 34 25 12 22 11 90 
排序后数组: 11 12 22 25 34 64 90 

相关推荐
Hello eveybody1 小时前
介绍一下动态树LCT(Python)
开发语言·python·算法
不穿铠甲的穿山甲1 小时前
MMR最大边际相关性
算法
handler011 小时前
速通蓝桥杯省一:二分算法
c语言·开发语言·c++·笔记·算法·职场和发展·蓝桥杯
炽烈小老头1 小时前
【 每天学习一点算法 2026/05/08】最小覆盖子串
学习·算法
汉克老师2 小时前
GESP5级C++考试语法知识(十六、分治算法(三))
c++·算法·分治算法·汉诺塔·逆序对·gesp5级·gesp五级
V搜xhliang02462 小时前
OpenClaw进阶完全教程
运维·人工智能·算法·microsoft·自动化
叼烟扛炮2 小时前
C++ 知识点12 构造函数
开发语言·c++·算法·构造函数
满天星83035772 小时前
定长内存池ObjectPool
数据结构·c++·算法·链表
叼烟扛炮2 小时前
C++第八讲:string 类
开发语言·c++·算法·string