快速排序

参考: 快速排序算法(图文并茂)

# quicksort
"""
1、首先认为第一个数是最小的,但实际上可能不是
2、那么就要遍历剩下的数,把比这个数小的放到它的左边,比这个数大的放到它的右边
3、左右开始往中间遍历,先右再左,按照2的规则排列,左右重合就是1中我们认为的这个数的位置
4、然后用3中这个位置的索引分成左右两个部分,继续重复1234步骤,即可排序
"""


def quick_sort(li, start, end):
    """
    li: 需要排序的列表
    start: 列表首位元素的索引
    end: 列表末位元素的索引
    """

    if start >= end:
        return

    n = len(li)
    # 认为0位置是中间值,记录中间值
    mid = li[start]
    # 定义两个游标
    left = start
    right = end

    while left < right:
        # 让右边游标往左移动,找到小于mid的值,放到左边游标位置
        while left < right and li[right] >= mid:
            right -= 1
        # 循环结束,放到左边游标位置
        li[left] = li[right]

        # 让左边游标往右移动,找到大于mid的值,放到右边游标位置
        while left < right and li[left] < mid:
            left += 1
        # 循环结束,放到右边游标位置
        li[right] = li[left]

    # left=right 把mid放到此位置
    li[left] = mid
    # 递归继续处理左边和右边的数据
    quick_sort(li, start, left - 1)
    quick_sort(li, left + 1, end)


if __name__ == '__main__':
    l = [4, 6, 2, 5, 1, 3]
    l = [6, 5, 3, 2, 1]
    l = [3, 1, 5, 6, 2, 4]
    # 3 [2,1,3,6,5,4]
    quick_sort(l, 0, len(l) - 1)
    print(l)
    # 稳定性:不稳定
    # 最坏时间复杂度:O(n^2)
    # 最优时间复杂度:O(nlogn)