【排序算法】典型排序算法和python 实现

以下是排序算法的分类及经典Python实现,包含时间复杂度、空间复杂度与稳定性说明:


一、比较类排序(通过元素间比较决定顺序)

1. 交换排序
  1. 冒泡排序

    时间复杂度:O(n²)(最优O(n)已优化)

    空间复杂度:O(1)

    稳定性:稳定

    python 复制代码
    def bubble_sort(arr):
        n = len(arr)
        for i in range(n):
            swapped = False
            for j in range(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
  2. 快速排序

    时间复杂度:平均O(n log n),最差O(n²)

    空间复杂度:O(log n)(递归栈)

    稳定性:不稳定

    python 复制代码
    def quick_sort(arr):
        if len(arr) <= 1:
            return arr
        pivot = arr[len(arr)//2]  # 选择中间元素为基准
        left = [x for x in arr if x < pivot]
        middle = [x for x in arr if x == pivot]
        right = [x for x in arr if x > pivot]
        return quick_sort(left) + middle + quick_sort(right)
2. 插入排序
  1. 直接插入排序
    时间复杂度:O(n²)(最优O(n))
    空间复杂度:O(1)
    稳定性:稳定

    python 复制代码
    def insertion_sort(arr):
        for i in range(1, len(arr)):
            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
3. 选择排序
  1. 简单选择排序
    时间复杂度:O(n²)
    空间复杂度:O(1)
    稳定性:不稳定

    python 复制代码
    def selection_sort(arr):
        for i in range(len(arr)):
            min_idx = i
            for j in range(i+1, len(arr)):
                if arr[j] < arr[min_idx]:
                    min_idx = j
            arr[i], arr[min_idx] = arr[min_idx], arr[i]
        return arr
4. 归并排序

时间复杂度:O(n log n)

空间复杂度:O(n)

稳定性:稳定

python 复制代码
def merge_sort(arr):
    if len(arr) <= 1:
        return arr
    mid = len(arr) // 2
    left = merge_sort(arr[:mid])
    right = merge_sort(arr[mid:])
    return merge(left, right)

def merge(left, right):
    res = []
    i = j = 0
    while i < len(left) and j < len(right):
        if left[i] <= right[j]:
            res.append(left[i])
            i += 1
        else:
            res.append(right[j])
            j += 1
    res.extend(left[i:] or right[j:])
    return res

二、非比较类排序(利用数值特征避免元素间比较)

1. 计数排序

时间复杂度:O(n + k)(k为数据范围)

空间复杂度:O(n + k)

稳定性:稳定(反向填充时)

适用场景:整数且范围较小

python 复制代码
def counting_sort(arr):
    max_val = max(arr)
    count = [0] * (max_val + 1)
    for num in arr:
        count[num] += 1
    res = []
    for i in range(len(count)):
        res.extend([i] * count[i])
    return res
2. 基数排序

时间复杂度:O(nk)(k为最大位数)

空间复杂度:O(n + k)

稳定性:稳定

python 复制代码
def radix_sort(arr):
    max_val = max(arr)
    exp = 1
    while max_val // exp > 0:
        buckets = [[] for _ in range(10)]
        for num in arr:
            buckets[(num // exp) % 10].append(num)
        arr = [num for bucket in buckets for num in bucket]
        exp *= 10
    return arr
3. 桶排序

时间复杂度:平均O(n + k),最差O(n²)

空间复杂度:O(n + k)

适用场景:均匀分布的数据

python 复制代码
def bucket_sort(arr, bucket_size=5):
    min_val, max_val = min(arr), max(arr)
    bucket_count = (max_val - min_val) // bucket_size + 1
    buckets = [[] for _ in range(bucket_count)]
    for num in arr:
        idx = (num - min_val) // bucket_size
        buckets[idx].append(num)
    res = []
    for bucket in buckets:
        res.extend(sorted(bucket))
    return res

三、总结对比

算法 最优时间 平均时间 最差时间 空间 稳定 适用场景
冒泡排序 O(n) O(n²) O(n²) O(1) 教学示例
快速排序 O(n log n) O(n log n) O(n²) O(log n) 通用高效排序
归并排序 O(n log n) O(n log n) O(n log n) O(n) 外部排序、稳定需求
计数排序 O(n + k) O(n + k) O(n + k) O(n + k) 小范围整数
基数排序 O(nk) O(nk) O(nk) O(n + k) 多位数整数

根据数据规模与类型选择合适算法:小数据用简单排序(如插入),大数据优先选O(n log n)算法,特定场景使用非比较排序。

相关推荐
weisian15123 分钟前
力扣经典算法篇-13-接雨水(较难,动态规划,加法转减法优化,双指针法)
算法·leetcode·动态规划
非小号23 分钟前
PaddleNLP 的文本分类项目
python·机器学习·分类
天才测试猿40 分钟前
自动化测试工具:Selenium详解
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
怀旧,1 小时前
【Python】2. 基础语法(2)
开发语言·python
敲代码的瓦龙1 小时前
C++?继承!!!
c语言·开发语言·c++·windows·后端·算法
简简单单做算法1 小时前
基于FPGA的二叉决策树cart算法verilog实现,训练环节采用MATLAB仿真
算法·决策树·fpga开发·cart算法·二叉决策树
小明小茗8861 小时前
DEBUG设置为False 时,django默认的后台样式等静态文件丢失的问题
python·django
安替-AnTi1 小时前
基于python+Django+Mysql的校园二手交易市场
python·mysql·django
白熊1881 小时前
【机器学习基础】机器学习入门核心算法:K-近邻算法(K-Nearest Neighbors, KNN)
算法·机器学习·近邻算法
wirepuller_king1 小时前
Python安装、pycharm配置和添加库下载
开发语言·python·pycharm