Python算法——冒泡排序

冒泡排序(Bubble Sort)是一种简单的排序算法,它通过反复交换相邻的元素,将较大的元素逐渐"浮"到数组的末尾,同时将较小的元素逐渐"沉"到数组的开头。冒泡排序是一种基本的比较排序算法,尽管不是最高效的排序算法,但它有助于理解排序算法的基本原理。本文将详细介绍冒泡排序的工作原理和Python实现。

冒泡排序的工作原理

冒泡排序的基本思想是通过多次遍历数组,依次比较相邻的两个元素,并根据比较结果交换它们的位置。每一轮遍历都会将一个最大(或最小)的元素"冒泡"到数组的末尾,因此称为"冒泡排序"。具体步骤如下:

  1. 从数组的第一个元素开始,依次比较相邻的两个元素。
  2. 如果前一个元素大于后一个元素,交换它们的位置。
  3. 继续遍历数组,直到没有交换操作发生。
  4. 重复以上步骤,直到整个数组有序。
下面是一个示例,演示冒泡排序的过程。我们以升序排序为例:

原始数组:[5, 1, 4, 2, 8]

  1. 第一轮遍历:[1, 5, 4, 2, 8](5和1交换)
  2. 第二轮遍历:[1, 4, 5, 2, 8](5和4交换)
  3. 第三轮遍历:[1, 4, 2, 5, 8](5和2交换)
  4. 第四轮遍历:[1, 4, 2, 5, 8](没有交换发生)
    重复以上步骤,直到整个数组有序。
Python实现冒泡排序

下面是Python中的冒泡排序实现:

python 复制代码
def bubble_sort(arr):
    n = len(arr)
    for i in range(n):
        swapped = False
        for j in range(0, n-i-1):
            if arr[j] > arr[j+1]:
                arr[j], arr[j+1] = arr[j+1], arr[j]  # 交换元素
                swapped = True
        if not swapped:
            break  # 如果没有交换,数组已经有序
  • arr 是待排序的数组。
  • n 表示数组的长度。
  • 外层循环 for i in range(n) 用于控制遍历的轮数。
  • 内层循环 for j in range(0, n-i-1) 用于执行具体的比较和交换操作。
  • 如果在一轮遍历中没有发生交换,说明数组已经有序,可以提前结束排序。

示例代码

下面是一个使用Python进行冒泡排序的示例代码:

python 复制代码
def bubble_sort(arr):
    n = len(arr)
    for i in range(n):
        swapped = False
        for j in range(0, n-i-1):
            if arr[j] > arr[j+1]:
                arr[j], arr[j+1] = arr[j+1], arr[j]
                swapped = True
        if not swapped:
            break

# 测试排序
arr = [5, 1, 4, 2, 8]
bubble_sort(arr)
print("排序后的数组:", arr)

时间复杂度

冒泡排序的时间复杂度为 O(n^2),其中 n 是数组的长度。尽管冒泡排序在大规模数据上不够高效,但它具有直观的实现和理解,适用于小型数据集或教育目的。

总之,冒泡排序是一种简单的排序算法,通过多次遍历和比较相邻元素来实现排序。了解冒泡排序有助于理解排序算法的基本原理,并为学习更高效的排序算法打下基础。

相关推荐
源码之家5 分钟前
基于Python房价预测系统 数据分析 Flask框架 爬虫 随机森林回归预测模型、链家二手房 可视化大屏 大数据毕业设计(附源码)✅
大数据·爬虫·python·随机森林·数据分析·spark·flask
CoderYanger11 分钟前
B.双指针——3194. 最小元素和最大元素的最小平均值
java·开发语言·数据结构·算法·leetcode·职场和发展·1024程序员节
SalvoGao12 分钟前
Python学习 | 怎么理解epoch?
数据结构·人工智能·python·深度学习·学习
楚疏笃1 小时前
纯Python 实现 Word 文档转换 Markdown
python·word
谅望者1 小时前
数据分析笔记08:Python编程基础-数据类型与变量
数据库·笔记·python·数据分析·概率论
mortimer1 小时前
【实战复盘】 PySide6 + PyTorch 偶发性“假死”?由多线程转多进程
pytorch·python·pyqt
清静诗意1 小时前
Django REST Framework(DRF)RESTful 最完整版实战教程
python·django·restful·drf
小曹要微笑1 小时前
STM32各系列时钟树详解
c语言·stm32·单片机·嵌入式硬件·算法
studytosky2 小时前
深度学习理论与实战:Pytorch基础入门
人工智能·pytorch·python·深度学习·机器学习
长不大的蜡笔小新2 小时前
手写数字识别:从零搭建神经网络
人工智能·python·tensorflow