冒泡排序(Bubble Sort)

冒泡排序(Bubble Sort)是一种简单直观的排序算法,它重复地遍历待排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。

以下是冒泡排序的基本步骤:

  1. 比较相邻元素:从数组的第一个元素开始,对每一对相邻元素进行比较。如果前一个元素大于后一个元素(对于升序排序),则交换这两个元素的位置。

  2. 遍历完整个数组:完成第一轮比较后,最大的元素会被"冒"到数组的末尾。接着对剩余未排序部分(即除了已排好序的最后一个元素外的部分)再次进行上述操作。

  3. 重复以上过程:持续进行上述两步操作,每次都会将当前未排序部分的最大元素"冒"到其所在子序列的末尾。随着遍历次数的增加,未排序部分逐渐减小,直至没有任何元素需要交换,即整个数组已排序。

时间复杂度

  • 最好情况(输入数组已经是有序的):只需进行一次遍历即可确认数组有序,无需进行任何交换,此时时间复杂度为 O(n)。
  • 最坏情况(输入数组逆序排列):需要进行 n-1 轮遍历,每轮都需要进行 n-i 次交换(i 表示当前轮次),因此总的交换次数为 n(n−1)/2,时间复杂度为 O(n2)。
  • 平均情况:时间复杂度也为 O(n2)。

空间复杂度:冒泡排序是原地排序算法,只需要常数级别的额外空间用于临时存储交换的元素,因此空间复杂度为 O(1)。

稳定性:冒泡排序是稳定的排序算法,即相同值的元素在排序前后相对位置不会改变。

虽然冒泡排序在实际应用中由于其较高的时间复杂度(尤其是在处理大规模数据时效率较低)而较少被直接使用,但它作为最基础的排序算法,易于理解、实现简单,常被用于教学和小型数据集的排序。对于规模较小且基本有序的数据,冒泡排序的表现可能优于更复杂的算法。

下面是一个简单的冒泡排序算法实现(以 Python 为例):

复制代码
复制代码
1def bubble_sort(arr):
2    n = len(arr)
3    
4    # 遍历所有数组元素
5    for i in range(n):
6        
7        # 每轮遍历中,设置一个标志位记录是否发生过交换,避免不必要的比较
8        swapped = False
9        
10        # 从数组的第一个元素开始,比较相邻元素并进行交换
11        for j in range(0, n-i-1):
12            
13            if arr[j] > arr[j+1]:
14                arr[j], arr[j+1] = arr[j+1], arr[j]
15                swapped = True
16                
17        # 如果一轮遍历中没有发生过交换,说明数组已经有序,提前结束排序
18        if not swapped:
19            break
20            
21    return arr

在这个改进版的冒泡排序中,引入了swapped标志来检测一轮遍历中是否发生过交换。如果没有发生交换,说明后续的元素已经有序,无需继续进行后续的遍历,从而优化了算法在最好情况下的性能。

相关推荐
测试员周周1 分钟前
【AI测试系统】第5篇:从 Archon 看 AI 工程化落地:为什么"确定性编排+AI 弹性智能"是终局?
人工智能·python·测试
智者知已应修善业5 分钟前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn7 分钟前
Java Set集合相关知识点
java·开发语言·算法
大飞记Python41 分钟前
【2026更新】Python基础学习指南(AI版)——04数据类型
开发语言·人工智能·python
生成论实验室1 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星1 小时前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
科研前沿2 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算
水蓝烟雨2 小时前
1931. 用三种不同颜色为网格涂色
算法·leetcode
Hello eveybody2 小时前
介绍一下背包DP(Python)
开发语言·python·动态规划·dp·背包dp
2301_795099742 小时前
让 CSS Grid 自适应容器尺寸的动态布局方案
jvm·数据库·python