码迷,mamicode.com
首页 > 编程语言 > 详细

快速排序(python版)

时间:2016-02-21 17:07:38      阅读:173      评论:0      收藏:0      [点我收藏+]

标签:

#!coding:utf8

def quicksort(list_num, left, right):
    if left > right:
        return

    low = left
    high = right
    privot= list_num[left]
    while low<high:
        while low < high and list_num[high] > privot:
            high-=1
        if low < high:
            list_num[low] = list_num[high]

        while low < high and list_num[low] <= privot:
            low+=1
        if low < high:
             list_num[high] = list_num[low]

    list_num[low] = privot
    quicksort(list_num, left, low-1)
    quicksort(list_num, low+1, right)

if __name__ == "__main__":
    test = [7,2,1,6,5,4,4,2]
    quicksort(test,0, len(test)-1)

后记:后面可以对privot游标的选择方法进行优化,如:三元中位法(每次选取三个位置(前,中,后)三个数的中位数的下标的值作为privot)

快速排序(python版)

标签:

原文地址:http://www.cnblogs.com/break-python/p/5205143.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!