Python 快速排序
基本原理:
利用递归的思想,在开始的时候选择一个基准值,大于这个基准值的数存放到一个列表中,其他值存放到另一个列表中,然后这两个列表进行递归操作。
时间复杂度为O(nlog2n),n为数组的个数。
空间复杂度为O(nlog2n)。
快速排序
def quick_sort(array): """ 快速排序 :param array: 数组 :return: (array)已排序的数组 """ # 递归退出的条件 length = len(array) if length <= 1: return array else: # 可以选第一个元素作为基准值,也可以选最后一个 pivot = array.pop() greater, lesser = [], [] for element in array: if element > pivot: greater.append(element) else: lesser.append(element) return quick_sort(lesser) + [pivot] + quick_sort(greater)
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/204708.html原文链接:https://javaforall.net
