python 实现快速排序

快速排序 的python 实现

之所以把快速排序放到单独一篇来写,一是这个面试时被问到的概率较大,二是快速排序是分治思想的最简单实现,以上为个人理解,如有不同,欢迎留言指正

# 快速排序python代码实现
import time
import random

# 自定义装饰器
def timer_count(f):
    def decor(*args,**kwargs):
        s_time = time.time()
        r = f(*args,**kwargs)
        e_time = time.time()
        print("{}函数耗时{}秒".format(f.__name__,e_time-s_time))
        return r
    return decor
'''
    快速排序思路:
        递归分治思想,每一轮循环都将待排序列表以某个值进行分割,然后依次递归处理
        实现代码如下:
'''

def quick_sort(l,start,end):
    i = start
    j = end
    # 凡是涉及到递归操作的函数,必须存在一个终止条件
    if i > j:
        return
    stand = l[start]      # 基准数值,一轮循环后以这个数为基准分为两部分,前方都比它小,后方都比它大
    while i < j:
        while i < j and l[j] >= stand:
            j -= 1
        # 这个小循环从后往前找,找到第一个比stand小的数,停止循环,输出当前的索引值
        l[i] = l[j]
        # 这里注意,这一次赋值后,列表中会出现两个l[j]的值,而l[i]被替换
        while i < j and l[i] <= stand:
            i += 1
        # 这个小循环从前往后找,找到第一个比stand大的数,停止循环,输出当前索引值
        l[j] = l[i]
        # 上一步赋值导致的列表中存在两个l[j]值,这一步赋值将后方的l[j]替换为l[i],最终列表中存在两个l[i]
    l[i] = stand
    quick_sort(l,start,i-1)
    quick_sort(l,i+1,end)

if __name__ == '__main__':
    l = [random.randint(10,99) for x in range(1000)]
    # ----------------------------本机测试超100万条数据就会出现栈溢出错误,待优化-----------------------------------------
    print("排序前:",l)
    s_time = time.time()
    quick_sort(l,0,len(l)-1)
    e_time = time.time()
    print("排序后:", l)
    print("{}程序耗时{}".format("快速排序",(e_time-s_time)))

快速排序相比上一篇稍微有点绕。最好是画个图时间过一遍,会发现非常简单,下一篇更新,希尔排序,堆排序,归并排序相关代码

初次写技术博客,目前肯定还存在很多不足之处,欢迎留言指正。:个人github地址

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值