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

相关推荐
测试1998几秒前
2024软件测试面试热点问题
自动化测试·软件测试·python·测试工具·面试·职场和发展·压力测试
love_and_hope几秒前
Pytorch学习--神经网络--搭建小实战(手撕CIFAR 10 model structure)和 Sequential 的使用
人工智能·pytorch·python·深度学习·学习
泉崎23 分钟前
11.7比赛总结
数据结构·算法
你好helloworld24 分钟前
滑动窗口最大值
数据结构·算法·leetcode
海阔天空_201329 分钟前
Python pyautogui库:自动化操作的强大工具
运维·开发语言·python·青少年编程·自动化
零意@37 分钟前
ubuntu切换不同版本的python
windows·python·ubuntu
思忖小下1 小时前
Python基础学习_01
python
AI街潜水的八角1 小时前
基于C++的决策树C4.5机器学习算法(不调包)
c++·算法·决策树·机器学习
q567315231 小时前
在 Bash 中获取 Python 模块变量列
开发语言·python·bash
是萝卜干呀1 小时前
Backend - Python 爬取网页数据并保存在Excel文件中
python·excel·table·xlwt·爬取网页数据