冒泡、选择、插入排序简介(Python)

冒泡排序(Bubble Sort)

冒泡排序通过重复遍历列表,比较相邻元素并交换位置,将较大元素逐渐"冒泡"到末尾。
时间复杂度 :平均和最坏情况为 O(n\^2),最好情况(已排序)为 O(n)
代码实现

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
    return arr

选择排序(Selection Sort)

选择排序每次遍历未排序部分,找到最小元素并交换到已排序部分的末尾。
时间复杂度 :始终为 O(n\^2)
代码实现

python 复制代码
def selection_sort(arr):
    n = len(arr)
    for i in range(n):
        min_idx = i
        for j in range(i+1, n):
            if arr[j] < arr[min_idx]:
                min_idx = j
        arr[i], arr[min_idx] = arr[min_idx], arr[i]
    return arr

插入排序(Insertion Sort)

插入排序将未排序元素逐个插入到已排序部分的正确位置,适合小规模或部分有序数据。
时间复杂度 :平均和最坏为 O(n\^2),最好为 O(n)
代码实现

python 复制代码
def insertion_sort(arr):
    n = len(arr)
    for i in range(1, n):
        key = arr[i]
        j = i - 1
        while j >= 0 and key < arr[j]:
            arr[j+1] = arr[j]
            j -= 1
        arr[j+1] = key
    return arr

总结

  • 冒泡排序:简单但效率低,适合教学或小数据集。
  • 选择排序:交换次数少,但不稳定。
  • 插入排序:对部分有序数据高效,常作为高级算法(如快速排序)的子过程。
相关推荐
JieE21211 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
金銀銅鐵16 小时前
[Python] 从《千字文》中随机挑选汉字
后端·python
cup1121 小时前
[技术复盘] Windows Python 打包实战:Nuitka 环境踩坑总结与 CI 自动化构建全指南
python·ai·环境变量·ci·nuitka·skill
aqi001 天前
15天学会AI应用开发(七)有了大模型为什么还要引入RAG
人工智能·python·大模型·ai编程·ai应用
金銀銅鐵1 天前
用 Python 实现 Take-Away 游戏
python·游戏
copyer_xyf1 天前
Agent 流程编排
后端·python·agent
copyer_xyf1 天前
Agent RAG
后端·python·agent
copyer_xyf1 天前
【RAG】向量数据库:milvus
后端·python·agent
copyer_xyf1 天前
Agent 记忆管理
后端·python·agent