快速排序
参考: 快速排序算法(图文并茂)
# 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)