冒泡、选择、插入排序简介(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

总结

  • 冒泡排序:简单但效率低,适合教学或小数据集。
  • 选择排序:交换次数少,但不稳定。
  • 插入排序:对部分有序数据高效,常作为高级算法(如快速排序)的子过程。
相关推荐
仰泳的熊猫21 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
qq_417695051 天前
机器学习与人工智能
jvm·数据库·python
无极低码1 天前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
漫随流水1 天前
旅游推荐系统(view.py)
前端·数据库·python·旅游
软件算法开发1 天前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
yy我不解释1 天前
关于comfyui的mmaudio音频生成插件时时间不一致问题(一)
python·ai作画·音视频·comfyui
superior tigre1 天前
22 括号生成
算法·深度优先
紫丁香1 天前
AutoGen详解一
后端·python·flask
FreakStudio1 天前
不用费劲编译ulab了!纯Mpy矩阵micronumpy库,单片机直接跑
python·嵌入式·边缘计算·电子diy