快速排序

#快速排序
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 -= 1
        data[left] = data[right]
        while left < right and data[left] <= tmp:
            left += 1
        data[right] = data[left]
    data[left] = tmp
    return left

快速排序,递归实现。一般时间长度O(nlogn)

posted @ 2018-02-08 15:02  colinshi  阅读(85)  评论(0编辑  收藏  举报