首页 > 其他分享 >C语言冒泡排序教程简介

C语言冒泡排序教程简介

时间:2025-01-05 23:31:28浏览次数:9  
标签:教程 int 交换 arr 冒泡排序 C语言 数组 排序

冒泡排序(Bubble Sort)是一种简单的排序算法,因其工作原理像气泡一样逐渐上浮而得名。其基本思想是通过一轮一轮地比较相邻的元素,将较大的元素逐步“冒泡”到数组的尾部。

在本篇博客中,我们将详细讲解冒泡排序的基本概念,如何在C语言中实现冒泡排序,并提供一些示例来帮助大家理解。


一、冒泡排序的原理

冒泡排序的核心思想是:通过多次遍历数组,将较大的元素逐步交换到数组的末端。每一轮遍历都会将一个最大的元素“冒泡”到正确的位置。

假设我们有一个数组 [5, 3, 8, 4, 2],冒泡排序的过程如下:

  1. 第一轮遍历:

    • 比较 53,因为 5 > 3,交换它们。
    • 比较 58,无需交换。
    • 比较 84,因为 8 > 4,交换它们。
    • 比较 82,因为 8 > 2,交换它们。

    第一轮之后,数组变成:[3, 5, 4, 2, 8]。此时,最大值 8 已经排好位置。

  2. 第二轮遍历:

    • 比较 35,无需交换。
    • 比较 54,因为 5 > 4,交换它们。
    • 比较 52,因为 5 > 2,交换它们。

    第二轮之后,数组变成:[3, 4, 2, 5, 8]。最大值 5 已经排好位置。

  3. 第三轮遍历:

    • 比较 34,无需交换。
    • 比较 42,因为 4 > 2,交换它们。

    第三轮之后,数组变成:[3, 2, 4, 5, 8]。最大值 4 已经排好位置。

  4. 第四轮遍历:

    • 比较 32,因为 3 > 2,交换它们。

    第四轮之后,数组变成:[2, 3, 4, 5, 8]。此时,所有元素已经按升序排列。


二、冒泡排序的代码实现

现在,让我们通过C语言代码来实现冒泡排序。

#include <stdio.h>

// 冒泡排序函数
void bubbleSort(int arr[], int n) {
    // 外层循环控制总的轮数
    for (int i = 0; i < n - 1; i++) {
        // 内层循环进行相邻元素的比较与交换
        for (int j = 0; j < n - 1 - i; j++) {
            if (arr[j] > arr[j + 1]) {
                // 交换元素
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

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

int main() {
    int arr[] = {5, 3, 8, 4, 2};  // 初始化数组
    int n = sizeof(arr) / sizeof(arr[0]);  // 计算数组元素个数

    printf("排序前的数组: ");
    printArray(arr, n);  // 输出排序前的数组

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

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

    return 0;
}

三、代码分析

  1. bubbleSort函数

    • 外层循环控制冒泡的轮数,每一轮都会将一个最大的元素“冒泡”到正确的位置。
    • 内层循环比较相邻的元素,如果前一个元素大于后一个元素,则交换它们的位置。
    • 注意:内层循环的次数随着外层循环的进行逐渐减少,因为每轮排序之后,最大的元素已经排好位置。
  2. printArray函数

    • 用于输出数组中的元素,帮助我们查看排序前后的数组状态。
  3. main函数

    • 创建一个数组,并初始化。
    • 输出排序前的数组。
    • 调用bubbleSort函数进行排序。
    • 输出排序后的数组。

四、冒泡排序的时间复杂度

冒泡排序的时间复杂度为 O(n²),其中 n 是数组的长度。由于冒泡排序需要进行两层嵌套循环:外层循环进行 n - 1 次遍历,内层循环最多进行 n - i 次比较和交换。

  • 最好情况:如果数组已经是有序的,冒泡排序仍然会进行 n - 1 轮遍历。此时,时间复杂度为 O(n),但这是一个理想情况。
  • 最坏情况:如果数组是逆序排列的,每一轮遍历都需要交换元素,时间复杂度为 O(n²)。
  • 平均情况:大部分情况下,时间复杂度为 O(n²)。

五、冒泡排序的优缺点

优点:
  • 简单易懂:冒泡排序是最简单的排序算法之一,非常适合初学者理解。
  • 原地排序:不需要额外的存储空间,只需常数空间。
缺点:
  • 效率低下:时间复杂度较高,特别是在处理大规模数据时,效率较低。
  • 交换次数多:在排序过程中频繁交换元素,可能会消耗较多的时间。

六、总结

冒泡排序是一种简单的排序算法,适合小规模数据的排序。当数据量较大时,冒泡排序的效率较低,通常不推荐使用。在实际开发中,我们更常使用其他更高效的排序算法,如快速排序或归并排序。

希望通过这篇博客,大家能够掌握冒泡排序的基本思想和实现方式,并能在实际编程中灵活运用。如果你有任何问题或疑惑,欢迎在评论区留言,我们一起讨论。

标签:教程,int,交换,arr,冒泡排序,C语言,数组,排序
From: https://blog.csdn.net/B5201234/article/details/144952710

相关文章

  • 【c# WPF贪吃蛇教程】Grid与UniformGrid一对异姓兄弟在二维世界玩蛇之幻觉让我骑大蛇
    前言    经过前面两次的贪吃蛇项目,我已经完全掌握了突破二维次元的绝对力量,一定要把小蓝(一只老鼠)从次壁中解救出来,键盘磨出的斑驳深痕被老祖的天门法眼洞悉,赐予我两枚绝域神器,分别是Grid和UniformGrid,奈何不好驾驭,但也阻挡不了我战胜蛇蛇的决心。。。    项......
  • SpringBoot进阶教程(八十四)spring-retry
    在日常的一些场景中,很多需要进行重试的操作.而spring-retry是spring提供的一个基于spring的重试框架,某些场景需要对一些异常情况下的方法进行重试就会用到spring-retry。spring-retry可以帮助我们以标准方式处理任何特定操作的重试。在spring-retry中,所有配置都是基于简单注释......
  • 深度学习CUDA环境安装教程---动手学深度学习
    首先说明我安装的是《动手学深度学习》中的环境本人是小白,一次安装,可能有不对的地方,望包含。安装CUDA因为我们是深度学习,很多时候要用到gpu进行训练,所以我们需要一种方式加快训练速度。通俗地说,CUDA是一种协助“CPU任务分发+GPU并行处理”的编程模型/平台,用于加速GPU和CPU之......
  • SQL 基础教程 - SQL SELECT 语句
    SQL SELECT 语句SELECT语句用于从数据库中选取数据。SQLSELECT语句SELECT语句用于从数据库中选取数据。结果被存储在一个结果表中,称为结果集。SQLSELECT语法SELECTcolumn1,column2,...FROMtable_name;与SELECT*FROMtable_name;参数说明:column1,co......
  • SQL 基础教程 - SQL UPDATE 语句
    SQL UPDATE 语句UPDATE语句用于更新表中的记录。SQLUPDATE语句UPDATE语句用于更新表中已存在的记录。SQLUPDATE语法UPDATEtable_nameSETcolumn1=value1,column2=value2,...WHEREcondition;参数说明:table_name:要修改的表名称。column1,column2,........
  • C语言指针数组在字符串的实例
    还记得指针数组吗?(一堆指针组成的数组)我们当时推荐字符串用这一块的内容,因为一句话可以用指针代替然后用指针数组组合在一起成为一个语句组成的的矩阵(总之就是攒在一起了方便操作),这一节也建议回顾一下字符串这一块,和string函数库基本格式与录入输出我们首先要创建一个指针数......
  • C语言结构体
    结构体很简单,就是结构,我们学过哪些结构?数组、指针数组等等能把一堆数据有结构、条例的组合在一起并且修改调用的,这块也是一个重要思维或者说分支,不亚于模块化(函数、文件)逻辑(逻辑条件),因此有些学校的编程课叫数据结构,就是因为它和c语言密不可分(尤其是c是内存操作的语言),数据结构......
  • C语言(自定义)函数
    函数概念函数可以分为函数库(预制菜)和自定义函数(自己做的菜)函数库之前的文章讲解过一部分数组的、字符串的、动态内存的,有兴趣可以我的学习专栏看一看,里面都有今天重点讲解的函数是自定义函数先来几道预制菜输入/输出函数(头文件为stdio.h):用于完成输入/输出功能;(最基本的)字......
  • C语言语法练习1(较简单)
    一、题目来源注意:题目来自牛客网链接:【新手上路】语法入门+算法入门题单_ACM竞赛_ACM/CSP/ICPC/CCPC/比赛经验/题解/资讯_牛客竞赛OJ_牛客网二、部分题目的解1、#include<stdio.h>intmain(){doublea,b,c;scanf("%lf%lf",&a,&b);c=(b/a)*100;pr......
  • Python入门教程 —— 模块和包
    1.导入模块Python中的模块在Python中有一个概念叫做模块(module)。说的通俗点:模块就好比是工具包,要想使用这个工具包中的工具(就好比函数),就需要导入这个模块。比如我们经常使用工具random,就是一个模块。使用importrandom导入工具之后,就可以使用random的函数。导入模......