冒泡排序:简单又易于实现的排序算法

news/2025/2/25 17:26:07

大家好,今天我们来聊聊 冒泡排序(Bubble Sort)算法。听名字是不是很简单,感觉就像是水面上泡泡一样?没错,冒泡排序的名字来源于这种排序过程中,较大的元素像气泡一样逐步“冒泡”到数组的顶端。虽然它不是效率最高的算法>排序算法,但它的简单性和易理解性使得它成为计算机科学入门算法之一。

在这篇博客中,我们将一步步了解冒泡排序的工作原理,分析它的时间复杂度,并通过 Java 代码实现这一经典算法

一、什么是冒泡排序?

冒泡排序是一种交换算法>排序算法,它通过多次遍历待排序的元素列表,每次比较相邻的两个元素,如果它们的顺序错误,就交换它们的位置。这样,每一轮比较都会将当前未排序部分的最大元素“冒泡”到正确的位置。

冒泡排序的步骤:
  1. 从数组的第一个元素开始,比较相邻的两个元素。
  2. 如果前一个元素大于后一个元素,则交换它们。
  3. 每一轮遍历都会将当前未排序部分的最大元素移到数组的末尾。
  4. 重复步骤 1 和步骤 2,直到所有元素都排好序。

二、冒泡排序的工作原理

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

  1. 第一轮遍历:

    • 比较 535 > 3,交换它们,得到 [3, 5, 8, 4, 2]
    • 比较 585 < 8,不交换
    • 比较 848 > 4,交换它们,得到 [3, 5, 4, 8, 2]
    • 比较 828 > 2,交换它们,得到 [3, 5, 4, 2, 8]
    • 第一轮结束,最大的元素 8 被冒泡到数组的最后。
  2. 第二轮遍历:

    • 比较 353 < 5,不交换
    • 比较 545 > 4,交换它们,得到 [3, 4, 5, 2, 8]
    • 比较 525 > 2,交换它们,得到 [3, 4, 2, 5, 8]
    • 第二轮结束,第二大的元素 5 被冒泡到倒数第二的位置。
  3. 第三轮遍历:

    • 比较 343 < 4,不交换
    • 比较 424 > 2,交换它们,得到 [3, 2, 4, 5, 8]
    • 第三轮结束,第三大的元素 4 被冒泡到倒数第三的位置。
  4. 第四轮遍历:

    • 比较 323 > 2,交换它们,得到 [2, 3, 4, 5, 8]
    • 第四轮结束,剩下的元素已经排好序。

到此为止,整个数组已经排好序了,排序结果是 [2, 3, 4, 5, 8]

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

冒泡排序的时间复杂度是 O(n²),其中 n 是数组的元素数量。原因如下:

  • 在最坏的情况下,冒泡排序需要进行 n-1 次遍历,每次遍历最多进行 n-1 次比较和交换操作。
  • 所以,时间复杂度是 O(n²),这也是为什么冒泡排序对于大规模数据集来说效率较低。
最好情况:
  • 如果数组已经是有序的,冒泡排序只需要进行一次遍历,时间复杂度为 O(n)
最坏情况:
  • 如果数组是倒序的,冒泡排序需要进行完全的遍历,时间复杂度为 O(n²)

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

冒泡排序是原地算法>排序算法,也就是说它只需要常数级的额外空间来交换元素。因此,它的空间复杂度为 O(1)

下面是一个用 Java 实现的冒泡排序代码:

public static void sort(int[] arr) {
        int len = arr.length;
        for (int j = 0; j < len; j++) {
            for (int i = 0; i < len - j - 1; i++) {
                if (arr[i] > arr[i + 1]) {
                    int temp = arr[i + 1];
                    arr[i + 1] = arr[i];
                    arr[i] = temp;
                }
            }
        }
    }

我们输入数组 {64, 34, 25, 12, 22, 11, 90},程序的输出是:

原始数组:
64 34 25 12 22 11 90 
排序后的数组:
11 12 22 25 34 64 90


http://www.niftyadmin.cn/n/5865763.html

相关文章

第4章 4.4 EF Core数据库迁移 Add-Migration UpDate-Database

4.4.1 数据库迁移原理 总结一下就是&#xff1a; 1. 数据库迁移命令的执行&#xff0c;其实就是生成在数据库执行的脚本代码&#xff08;两个文件&#xff1a;数字_迁移名.cs 数字_迁移名.Designer.cs&#xff09;&#xff0c;用于对数据库进行定义和修饰。 2. 数据库迁移…

java23种设计模式-原型模式

原型模式&#xff08;Prototype Pattern&#xff09;学习笔记 &#x1f31f; 定义 原型模式属于创建型设计模式&#xff0c;通过复制现有对象&#xff08;原型&#xff09;来创建新对象&#xff0c;避免重复进行初始化操作。该模式的核心是实现对象的克隆能力。 &#x1f3af…

基于深度学习的SSD口罩识别项目完整资料版(视频教程+课件+源码+数据)

基于深度学习的SSD口罩识别项目完整资料版&#xff0c;包含视频教程、PPT课件和源码. 01 项目介绍.mp4 02 SSD算法原理回顾.mp4 03 数据集收集.mp4 04 自定义数据集.mp4 05 生成anchors.mp4 06 展示anchors.mp4 07 计算iou值.mp4 08 计算target.mp4 09 定义模型.mp4 10 模型训练…

【开关电源】汽车前端电源保护电路设计

前言&#xff1a; 汽车电池端子在启动或者保养过程中被反接&#xff0c;如果对这些故障不能及时处理&#xff0c;就可能导致ECU或供电设备被损坏&#xff1b;此外在供电过程中电压也存在不稳定的情况。在EMC测试中ISO16750和ISO7637也会有负电压的情况。 肖特基二极管和 P 沟道…

抖音营销创新策略与案例分析:以奈雪的茶为例及开源AI智能名片2+1链动模式S2B2C商城小程序的启示

摘要&#xff1a;随着互联网技术的快速发展&#xff0c;社交媒体平台已成为品牌推广和市场营销的重要阵地。抖音作为短视频领域的佼佼者&#xff0c;凭借其庞大的用户基础和强大的算法推荐机制&#xff0c;为众多品牌提供了广阔的营销空间。本文以奈雪的茶在抖音的6周年营销活动…

计算机视觉算法

计算机视觉算法简介 计算机视觉(Computer Vision)作为人工智能的一个重要分支,致力于让计算机能够“看”并理解图像或视频中的内容。其应用领域广泛,从自动驾驶汽车、医疗影像分析到增强现实和安全监控等。随着深度学习技术的发展,计算机视觉已经取得了显著的进展,尤其是…

ARM-Linux 基础项目篇——简单的视频监控

该基础项目为后面的 AI 安防项目做铺垫。使用 Qt 的网络编程方案来实现&#xff0c;后期再实现流媒体协议的方案。使用 ov2640 摄像头。 一、实现流程 &#xff08;1&#xff09; 服务器采集摄像头的数据。 &#xff08;2&#xff09; 处理视频数据转交给 Socket&#xff0c;…

CSS滚动条原理与自定义样式指南,CSS滚动条样式失效,滚动条样式无效,-webkit-scrollbar无效,overflow不显示滚动条

滚动内容形成的必要条件 CSS Overflow属性解析 MDN官方文档-Overflow属性 菜鸟教程-Overflow属性 overflow 属性控制内容溢出元素框时在对应的元素区间内是否添加滚动条。 值描述visible默认值。内容不会被修剪&#xff0c;会呈现在元素框之外。hidden内容会被修剪&#xf…