python实现快速排序

快速排序思想:冒泡排序的进阶版本,也用到了分治思想和递归

快速排序原理:

①先从队尾开始向前扫描且当low < high时,如果li[high] >li[0],则high–,但如果li[high] < li[0],则将high的值赋值给low,即li[low] = li[high],同时要转换数组扫描的方式,即需要从队首开始向队尾进行扫描了


②同理,当从队首开始向队尾进行扫描时,如果li[low] < li[0],则low++,但如果li[low] > li[0]了,则就需要将low位置的值赋值给high位置,即li[low] = li[high],同时将数组扫描方式换为由队尾向队首进行扫描.


③不断重复①和②,知道low>=high时(其实是low=high),low或high的位置就是该基准数据在数组中的正确索引位置.

 

 

l = [0, 5, 13, 26, 20, 15, 65, 41, 51]


def partition_hwq(li, i, j):
    povotkey = li[i]
    li[0] = povotkey
    while i < j:
        while i < j and li[j] >= povotkey:
            j -= 1
        li[i] = li[j]
        while i < j and li[i] <= povotkey:
            i += 1
        li[j] = li[i]
    li[i] = li[0]
    return i


def qsort(li, i, j):
    if i < j:
        partition_hwq(li, i, j)
        qsort(li, i, partition_hwq(li, i, j)-1)
        qsort(li, partition_hwq(li, i, j)+1, j)


def quick_sort(li, n):
    qsort(li, 1, n)


quick_sort(l, len(l)-1)
print(l)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值