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

排序算法Nb三人组-快速排序

时间:2019-02-25 18:15:10      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:思想   图片   while   turn   span   pre   com   列表   return   

核心思想:

技术图片

将列表中第一个元素拿出来,放到一边,左右两个循环,左面的大于拿出来的数,就把他挪到右面,

右面的小于拿出来的数就把他放在左面,这是列表被第一个元素‘‘分‘‘为两个列表,在对两个列表进行同样的操作进行递归.

def partition(li, left, right):
    tmp = li[left]
    while left < right:
        while left < right and li[right] >= tmp:
            right -= 1
        li[left] = li[right]
        while left < right and li[left] <= tmp:
            left += 1
        li[right] = li[left]
    li[left] = tmp
    return left
def quick_sort(li, left, right):
    if left < right: # 待排序的区域至少有两个元素
        mid = partition(li, left, right)
        quick_sort(li, left, mid-1)
        quick_sort(li, mid+1, right)

 

排序算法Nb三人组-快速排序

标签:思想   图片   while   turn   span   pre   com   列表   return   

原文地址:https://www.cnblogs.com/Treasuremy/p/10432339.html

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