数据结构算法--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)

相关推荐
白日做梦Q几秒前
Anchor-free检测器全解析:CenterNet vs FCOS
python·深度学习·神经网络·目标检测·机器学习
吃杠碰小鸡几秒前
高中数学-数列-导数证明
前端·数学·算法
故事不长丨几秒前
C#线程同步:lock、Monitor、Mutex原理+用法+实战全解析
开发语言·算法·c#
long3161 分钟前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法
近津薪荼2 分钟前
dfs专题4——二叉树的深搜(验证二叉搜索树)
c++·学习·算法·深度优先
熊文豪10 分钟前
探索CANN ops-nn:高性能哈希算子技术解读
算法·哈希算法·cann
喵手14 分钟前
Python爬虫实战:公共自行车站点智能采集系统 - 从零构建生产级爬虫的完整实战(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集公共自行车站点·公共自行车站点智能采集系统·采集公共自行车站点导出csv
喵手22 分钟前
Python爬虫实战:地图 POI + 行政区反查实战 - 商圈热力数据准备完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·地区poi·行政区反查·商圈热力数据采集
熊猫_豆豆27 分钟前
YOLOP车道检测
人工智能·python·算法
nimadan1228 分钟前
**热门短剧小说扫榜工具2025推荐,精准捕捉爆款趋势与流量
人工智能·python