快速排序(Quick Sort)
快速排序是一种高效的排序算法,采用分治法(Divide and Conquer)策略。它的基本思想是:选择一个基准元素(pivot),将数组分为两部分,使得左边部分的元素都小于基准元素,右边部分的元素都大于基准元素,然后递归地对左右两部分进行排序。
快速排序的步骤:
- 选择基准元素:从数组中选择一个元素作为基准(通常选择第一个、最后一个或中间元素)。
- 分区操作:将数组分为两部分,左边部分的元素小于基准元素,右边部分的元素大于基准元素。
- 递归排序:对左右两部分递归地应用快速排序。
- 合并结果:由于分区操作已经保证了左边部分小于右边部分,最终数组自然有序。
时间复杂度:
- 最坏情况:O(n²) —— 当每次选择的基准元素都是最小或最大元素时。
- 最好情况:O(n log n) —— 当每次选择的基准元素都能将数组均匀分为两部分时。
- 平均情况:O(n log n)
空间复杂度:
- O(log n) —— 递归调用栈的深度。
Python 实现
def quick_sort(arr):
if len(arr) <= 1:
return arr
pivot = arr[len(arr) // 2] # 选择中间元素作为基准
left = [x for x