快速排序

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


def partition(data, left, right):
    tmp = data[left]
    while left < right:
        while left < right and data[right] > tmp:
            right = right - 1
        data[left] = data[right]
        while left < right and data[left] < tmp:
            left = left + 1
        data[right] = data[left]
    data[left] = tmp
    return left


li = [32, 29, 14, 37, 20]
quick_sort(li, 0, 4)
print(li)
posted @ 2018-11-08 11:49  桥前石头  阅读(107)  评论(0编辑  收藏  举报