Python随笔-快排

Posted 一觉睡到小时候

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python随笔-快排相关的知识,希望对你有一定的参考价值。

def swap(arr, i, j):
    temp = arr[i]
    arr[i] = arr[j]
    arr[j] = temp

def part(arr, beg, end):
    if end - beg <= 0:
        return beg
    v = arr[beg]
    idx = beg + 1
    for x in range(beg+1, end+1):
        if(arr[x] < v):
            swap(arr, idx, x)
            idx += 1
    swap(arr, idx-1, beg)
    return idx-1


def sort(arr, beg, end):
    if end - beg <= 0:
        return
    i = part(arr, beg, end)
    sort(arr, beg, i)
    sort(arr, i+1, end)

arr = [5, 10, 6, 7, 1, 2, 3, 0, 3, 10, 99, 22, 33, 23, 45]
sort(arr, 0, len(arr)-1)
print(arr)

 

以上是关于Python随笔-快排的主要内容,如果未能解决你的问题,请参考以下文章

一篇无聊的随笔

python快排

用python写个快排

快排用Python的实现 - 简洁方式

Python实现快排 𱛡

Python实现快排 -- 2019-08-09 12:12:36