当前位置: 首页 > news >正文

Python实现快速排序的三种经典写法及算法解析

今天想熟悉一下python的基础写法,那就从最经典的快速排序来开始吧:

1、经典分治写法(原地排序)
时间复杂度:平均O(nlogn),最坏O(n²)
空间复杂度:O(logn)递归栈空间
特点:通过左右指针交换实现原地排序

def quick_sort(arr, low, high):
    if low < high:
        pi = partition(arr, low, high)
        quick_sort(arr, low, pi-1)
        quick_sort(arr, pi+1, high)

def partition(arr, low, high):
    pivot = arr[high]
    i = low - 1
    for j in range(low, high):
        if arr[j] <= pivot:
            i += 1
            arr[i], arr[j] = arr[j], arr[i]
    arr[i+1], arr[high] = arr[high], arr[i+1]
    return i + 1

2、Pythonic简洁写法(非原地)
特点:利用列表推导式,代码更简洁但需要额外空间

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)

 

3、尾递归优化写法
特点:减少递归深度,避免栈溢出风险

quick_sort(arr, low=0, high=None):
    if high is None:
        high = len(arr) - 1
    while low < high:
        pi = partition(arr, low, high)
        if pi - low < high - pi:
            quick_sort(arr, low, pi-1)
            low = pi + 1
        else:
            quick_sort(arr, pi+1, high)
            high = pi - 1
    return arr

算法核心思想:分治法+基准值选取。第一种实现最接近传统快速排序定义,第二种适合教学演示,第三种适合处理大数据集。实际使用时建议添加随机化基准值选择来避免最坏情况。

相关文章:

  • kafka消息积压排查
  • 在 Kali 上打造渗透测试专用的 VSCode 环境
  • RabbitMQ 学习
  • Power Query动态追加查询
  • 品牌坚持电商控价的底层逻辑与实施价值
  • 【Elasticsearch】映射:Nested 类型
  • 神经网络-Day46
  • 单元测试与QTestLib框架使用
  • Python打卡训练营学习记录Day46
  • WiFi通信应用开发【保姆级】+配置ESP8266芯片的WiFi station和soft-AP + station工作模式!!!
  • 基于 actix-web 框架的简单 demo
  • Proxmox Mail Gateway安装指南:从零开始配置高效邮件过滤系统
  • DIY|Mac 搭建 ESP-IDF 开发环境及编译小智 AI
  • Pycharm中添加不了新建的Conda环境(此篇专门给Daidai写的)
  • 衡量嵌入向量的相似性的方法
  • 服务器磁盘空间被Docker容器日志占满处理方法
  • 青少年编程与数学 01-011 系统软件简介 05 macOS操作系统
  • 基于IDIG-GAN的小样本电机轴承故障诊断
  • Mac下Android Studio扫描根目录卡死问题记录
  • WebRTC 与 WebSocket 的关联关系
  • 山东泰山队深圳队/临沂seo整站优化厂家
  • 网站统计代码/台州seo
  • 图书网站怎么做/郑州百度网站快速优化
  • 怎么做猫的静态网站/网站优化推广外包
  • 网站如何添加统计代码/天眼查询个人信息
  • 厦门网站建设公司怎么选/天津建站网