时间复杂度 | 名称 | 示例算法 |
---|---|---|
O(1) | 常数时间复杂度 | 哈希表查找 |
O(logn) | 对数时间复杂度 | 二分查找 |
O(n) | 线性时间复杂度 | 遍历数组 |
O(nlogn) | 线性对数时间复杂度 | 快速排序 |
O(n^2) | 平方时间复杂度 | 冒泡排序、插入排序 |
O(n^3) | 立方时间复杂度 | 矩阵乘法 |
O(2^n) | 指数时间复杂度 | 穷举搜索 |
O(n!) | 阶乘时间复杂度 | 旅行商问题 |
O(1) < O(logn) < O(n) < O(nlogn) < O(n^2) < O(n^3) < O(2^n) < O(n!)
快速排序(Quick Sort)是一种基于分治思想的排序算法,是目前使用最广泛的排序算法之一。其基本思想是选取一个基准元素,然后将数组分成小于等于基准的子数组和大于基准的子数组,再递归地对这两个子数组进行快速排序,最后将它们合并起来即可。
快速排序:
的核心操作是分割数组
操作
划分操作采用两种方式:Lomuto 分割和 Hoare 分割。
复杂度 | |
---|---|
最坏复杂度 | n^2 |
平均复杂度 | nlong |
递归复杂度 | nlong |
快速排序的基本步骤:
选择基准元素
:从待排序数组中选择一个元素作为基准(通常选择第一个元素)分割数组:
重新排列数组,将所有小于基准的元素放在基准的左边,所有大于基准的元素放在基准的右边,等于基准的元素可以放在任意一边。此时,基准元素的位置也已经确定递归排序:
递归地对基准元素左边的子数组和右边的子数组进行快速排序合并结果:
将左边子数组、基准元素、右边子数组依次拼接起来,得到排好序的数组def quicksort(arr):# 如果数组长度小于等于1,则直接返回该数组if len(arr) <= 1:return arrelse:# 选择第一个元素作为基准pivot = arr[0]# 构造小于等于基准的元素构成的子数组 less 构造大于基准的元素构成的子数组 greaterless = [x for x in arr[1:] if x <= pivot] # 输出比第一个元素小的列表greater = [x for x in arr[1:] if x > pivot] # 输出比第一个元素大的列表print('less-----------', less)print('greater-----------', greater)# 递归地对这两个子数组进行快速排序,然后将它们合并起来,并加上基准元素return quicksort(less) + [pivot] + quicksort(greater)if __name__ == '__main__':arr = [3, 5, 2, 8, 1, 4]sorted_arr = quicksort(arr)print(sorted_arr)