数据结构算法--3快速排序

快速排序比冒泡排序,选择排序,插入排序速度都快

快速排序思路:

^取一个元素P,(第一个元素),使元素P归位。

^列表被P分成了两部分,左边都比P小,右边都比P大。

^递归完成排序。

过程:

把5拿出来存到tmp,5的位置是指针left,right指针在8,8>5,right指针-1,9又>5,right再次-1

right来到2,2<5,所以left指针处(5),成为2,此时right指针成为空元素(原来2的位置),所以left指针+1,left到了元素7,由于7>5,所以7要去列表右侧,所以right指针处(原来2的位置),变为7,依次类推,两指针交替变换

完成第一轮归位后,左侧和右侧再次分别进行归位,递归完成排序

python 复制代码
def quick_sort(li,left,right):  # 一开始传进来left=0
    if left<right:
        mid=partition(li,left,right)  # 返回下标值,从列表第一个值开始,每次定位在中间值
        quick_sort(li,left,mid-1)
        quick_sort(li,mid+1,right)
python 复制代码
def partition(li,left,right):
    tmp=li[left]            # 把第一个值存起来
    while left<right:
        while left<right and li[right]>tmp:
            right-=1   # 往左走一步
        li[left]=li[right]   # 右边的值写到左边空位上
        while left<right and li[left]<=tmp:
            left+=1
        li[right]=li[left]  # 把左边的值写到右边空位
    li[left]=tmp            # 把tmp归位
    return left             # 返回mid值,left,right都行

如果是一个原本就逆序的数列要排成顺序数列,每一轮都只确定了基准元素的位置

这时最坏情况,时间复杂度退化成了O(n方)

我们可以避免这种最坏情况的发生,随机选择一个元素作为基准元素(不是第一个)

这样快速排序时间复杂度可以看出是O(nlogn)

相关推荐
小白程序员成长日记3 分钟前
2025.11.08 力扣每日一题
算法·leetcode·职场和发展
我的xiaodoujiao8 分钟前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 24--数据驱动--参数化处理 Excel 文件 1
python·学习·测试工具·pytest
Nebula_g11 分钟前
C语言应用实例:学生管理系统1(指针、结构体综合应用,动态内存分配)
c语言·开发语言·学习·算法·基础
小叮当⇔11 分钟前
“征服式学习”提示词工具箱
学习·算法
惊讶的猫14 分钟前
字符串- 字符串转换整数 (atoi)
数据结构·算法
开心-开心急了23 分钟前
关于Flutter与Qt for python 的一些技术、开源、商用等问题
开发语言·python·qt·flutter
@小码农1 小时前
2025年北京海淀区中小学生信息学竞赛第一赛段试题(附答案)
人工智能·python·算法·蓝桥杯
2301_795167201 小时前
玩转Rust高级应用 如何让让运算符支持自定义类型,通过运算符重载的方式是针对自定义类型吗?
开发语言·后端·算法·安全·rust
laocooon5238578861 小时前
C语言 有关指针,都要学哪些内容
c语言·数据结构·算法
多多*1 小时前
牛客周赛 Round 114 Java题解
算法