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

相关推荐
hnmpf2 分钟前
flask-admin modelview 中重写get_query函数
后端·python·flask
Xenia2235 分钟前
复习篇~第二章程序设计基础
c++·算法
清炒孔心菜6 分钟前
每日一题 342. 4的幂
leetcode
想睡觉 . 我也想睡觉 .12 分钟前
【C++算法】1.【模板】前缀和
开发语言·c++·算法
天天要nx13 分钟前
D105【python 接口自动化学习】- pytest进阶参数化用法
python·pytest
mit6.82415 分钟前
[数据结构] LRU Cache | List&Map 实现
算法
是十一月末23 分钟前
Opencv实现图片和视频的加噪、平滑处理
人工智能·python·opencv·计算机视觉·音视频
yuanbenshidiaos23 分钟前
数据结构----链表头插中插尾插
网络·数据结构·链表
逊嘘34 分钟前
【Java数据结构】LinkedList
java·开发语言·数据结构
周盛欢34 分钟前
云服务器yum无法解析mirrorlist.centos.org
开发语言·python