快速排序案例演示

def quick_sort(arr, low, high):
    """
    快速排序
    :param arr: 待排序数组
    :param low: 数组起始索引
    :param high: 数据结束索引
    :return: 排好序数组
    """
    if low >= high:
        return arr
    mid_value = arr[low]

    while low < high:
        # 如果 low<high 并且 大游标的值 大于等于 中间值,那么符合要求。-1 游标往下走
        # 如果 大游标的值 小于 中间值时,while不成立,此时大游标对应的值 附给 小游标的值
        while low < high and arr[high] >= mid_value:
            high -= 1
        arr[low] = arr[high]

        while low < high and arr[high] <= mid_value:
            low += 1
        arr[high] = arr[low]

    # 循环退出时, low=high
    arr[low] = mid_value

    return arr
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值