Python算法--快速排序

本文深入讲解了快速排序算法的实现原理及步骤,包括如何通过比较和替换元素来找到中间点,进而将列表分为两部分进行递归排序。文章提供了一个Python实现的例子,详细解释了partition和quick_sort两个核心函数的工作流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

def partition(left,right,list):
    # 将左起第一个数字存储起来,记为初始值,并将该位置记为替换点
    mep_log = list[left]
    #开始循环比较
    while left < right:
        # 降序的话 改变这两个while最后的比较符
        # 这两个while最后的比较符,不加=会不能判断形同数字的
        # 右起循环,获得比初始值小的数字
        while left<right and list[right] <= mep_log:
            right -= 1
        # 将右边更小值替换到替换点上,并将替换点改为右侧现在的下角标--right
        list[left] = list[right]
        # 左起循环,获取比初始值大的数字
        while left < right and list[left] > mep_log:
            left += 1
        # 和将左边更大值替换到替换点上,并将替换点改为左侧现在的下角标--left
        list[right] =list[left]
    # 一顿操作猛如虎,现在以left为中点,左边的都比右边的小,而left上的值是介于二者之间的
    list[left] = mep_log
    return left # 返回标记

# 快速排序  复杂度最佳情况是O(nlogn),最差情况是O(n^2)
# 比较-替换-找中点-分为两份-分别(比较-替换-找中点)n-最后形成排序
#left right 左右比较的开始位置,一般为0, len-1
def quick_sort(left,right,list):
    if left < right: # 递归的判断
        #以左边为基准,获取第一次左边替代右的数字的位置
        mid = partition(left, right, list)
        #列表分为以mid为中点的两部分(不平均)
        # 排序左侧
        quick_sort(left,mid-1,list)
        # 排序右侧
        quick_sort(mid+1,right,list)
    return list

list = [3,1,5,7,3,8,6,2,0,4,9]
print(quick_sort(0,10,list))

是学习了https://www.cnblogs.com/BigJ/p/7601817.html之后写的,很像,但是原文的快速排序不能运行,也算原创吧,如果不算请指正。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值