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

总结

  • 冒泡排序:简单但效率低,适合教学或小数据集。
  • 选择排序:交换次数少,但不稳定。
  • 插入排序:对部分有序数据高效,常作为高级算法(如快速排序)的子过程。
相关推荐
言無咎2 分钟前
从规则引擎到任务规划:AI Agent 重构跨境财税复杂账务处理体系
大数据·人工智能·python·重构
naruto_lnq3 分钟前
C++中的桥接模式
开发语言·c++·算法
苦藤新鸡3 分钟前
50.腐烂的橘子
数据结构·算法
张小凡vip7 分钟前
数据挖掘(十)---python操作Spark常用命令
python·数据挖掘·spark
想进个大厂9 分钟前
代码随想录day32 动态规划01
算法·动态规划
U盘失踪了14 分钟前
Reqable 导出响应数据
python
2301_7903009618 分钟前
数据分析与科学计算
jvm·数据库·python
j4455661122 分钟前
C++中的职责链模式高级应用
开发语言·c++·算法
uesowys25 分钟前
Apache Spark算法开发指导-Decision tree classifier
算法·决策树·spark
程序员小远33 分钟前
使用Postman进行一次完整的接口测试
自动化测试·软件测试·python·测试工具·测试用例·接口测试·postman