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

相关推荐
代码无bug抓狂人2 分钟前
动态规划(附带入门例题)
c语言·算法·动态规划
whale fall3 分钟前
celery -A tool.src.main worker --loglevel=info --queues=worker1_queue & 什么意思
python·学习·apache
naruto_lnq7 分钟前
使用Fabric自动化你的部署流程
jvm·数据库·python
喵手15 分钟前
Python爬虫实战:采集博客园 Cnblogs文章标题、发布日期、标签以及HTML正文等(附 Markdown 文档格式预览)!
爬虫·python·爬虫实战·python爬虫工程化实战·零基础python爬虫教学·博客园文章采集·博客园文章采集转md格式
OLOLOadsd12317 分钟前
柑橘类水果病害识别与分级_faster-rcnn_hrnetv2p-w32-1x_coco实现
python
weixin_4454023020 分钟前
C++中的命令模式变体
开发语言·c++·算法
季明洵21 分钟前
C语言实现顺序表
数据结构·算法·c·顺序表
Hgfdsaqwr28 分钟前
实时控制系统优化
开发语言·c++·算法
2301_821369611 小时前
嵌入式实时C++编程
开发语言·c++·算法