排序算法--冒泡排序

冒泡排序虽然简单,但在实际应用中效率较低,适合小规模数据或教学演示。

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;
            }
        }
    }
}
cpp 复制代码
#include <stdio.h>
void printArray(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("排序前的数组: \n");
    printArray(arr, n);

    bubbleSort(arr, n); // 调用冒泡排序函数

    printf("排序后的数组: \n");
    printArray(arr, n);

    return 0;
}

优化建议

1)提前终止:如果某一轮没有发生交换,说明数组已有序,可以提前结束排序。

cpp 复制代码
// 冒泡排序函数
void bubbleSortOptimized(int arr[], int n) {
    int swapped;
    for (int i = 0; i < n - 1; i++) {// 外层循环控制排序轮数
        swapped = 0;
        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;
                swapped = 1;
            }
        }
        if (!swapped) break; // 如果没有交换,提前结束
    }
}

2)记录最后交换位置:记录每轮最后一次交换的位置,减少不必要的比较。

相关推荐
半盏茶香4 分钟前
启航数据结构算法之雅舟,悠游C++秘境——单链表之美妙构筑
数据结构·c++·算法
小林熬夜学编程23 分钟前
【MySQL】第二弹---数据库基础全解析:从概念到实践的深度探索
linux·开发语言·数据库·mysql·算法
思麟呀39 分钟前
栈和队列的实现(C语言)
c语言·数据结构·学习
byte轻骑兵1 小时前
嵌入式C语言:大小端详解
c语言·开发语言·嵌入式软件开发
怎么这么多名字都被占了1 小时前
llama.cpp的C语言API使用
c语言·人工智能·llama
中东大鹅1 小时前
【排序算法】选择排序
数据结构·算法·排序算法
阿巴~阿巴~1 小时前
初识C语言、C语言的学习方向总述与入门
c语言·开发语言
Power++1 小时前
【BUUCTF逆向题】[2019红帽杯]easyRE
c语言·c++·python·网络安全·系统安全·密码学
九亿AI算法优化工作室&2 小时前
【SOC估计】基于扩展卡尔曼滤波器实现锂离子电池充电状态估计matlab代码和报告
开发语言·人工智能·算法·matlab·数据挖掘·回归
皎味小行家2 小时前
第四十六天|动态规划|子序列|647. 回文子串,5.最长回文子串, 516.最长回文子序列,动态规划总结篇
java·数据结构·算法·leetcode·动态规划