python实现快排

思路

如果数组内元素不为空

  • 对于第一个元素,将小于它的放左边,将大于它的放在右边
  • 将左边的元素进行第一步的过程
  • 将右边的元素进行第一步的过程

代码

import random
x = [random.randint(0, 199) for i in range(130)]


def quick_sort(value, left, right):
    if left < right:
        mid = partition(value, left, right)
        quick_sort(value, left, mid-1)
        quick_sort(value, mid+1, right)

# 取出左边的第一个元素temp,让左边产生空位
# 从右边找比temp小的,两者交换,让右边产生空位
# 从左边找比temp大的,两者交换,让左边产生空位
# 循环2、3步
# 把temp放到合适的位置
def partition(value, left, right):
    temp = value[left]
    while left < right:
        while left < right and value[right] >= temp:
            right -= 1
        value[right], value[left] = value[left], value[right]
        while left < right and value[left] <= temp:
            left += 1
        value[left], value[right] = value[right], value[left]
    value[left] = temp
    return left

quick_sort(x, 0, len(x)-1)
assert x == sorted(x)

记录

while left < right and value[right] >= temp:
对于这一行,我开始写的时候是
while left < right and value[right] >temp:
这么写的。在列表中含重复元素的情况下,这样会产生一个死循环。

启发

若在这种含有比较大小、且是while循环下,为了保证代码正确,不出现死循环,需保证

  • 大小比较条件只出现真假两种情况,即 ≥ \ge ≤ \le

这么做的原因是循环执行的条件只能为真,如果在循环体中无法改变这个状态,则无法保证需要跳出循环的代码的正确性

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值