快速排序
快速排序(Quicksort)是对冒泡排序的一种改进。
快速排序由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。
def quick_sort(alist, first, last):
if first >= last:
return
mid_value = alist[first]
low = first
high = last
while low < high:
while low < high and alist[high] >= mid_value:
high -= 1
alist[low] = alist[high]
while low < high and alist[low] < mid_value:
low += 1
alist[high] = alist[low]
alist[low] = mid_value
quick_sort(alist, first, low-1)
quick_sort(alist, low+1, last)
if __name__ == '__main__':
li = [1, 3, 4, 2, 9, 5, 8]
print(li)
quick_sort(li,0,len(li)-1)
print(li)
思路:给定一个中间值和两个下标low和high,同时都对中间值作比较,将相等的情况都统一到一边,否者会造成low和high错过的情况,使用递归的思想,因为是对同一个列表上做操作
快速排序是不稳定的,最优时间复杂度O(n*logn),最坏时间复杂度O(n**2)-->(本来就是顺序的)