快速排序是一种基于分治思想的高效排序算法,核心逻辑是通过选取基准元素将待排序序列分成两个子序列,再对子序列递归执行相同操作,最终完成整个序列的排序。它的平均时间复杂度为O(n log n),在很多场景下比冒泡排序、选择排序等基础排序算法效率更高。

快速排序的核心步骤
快速排序的运作过程可以拆解为三个核心环节,每个环节的执行逻辑如下:
1. 选择基准元素
基准元素是快速排序的核心参考点,通常可以选择序列的第一个元素、最后一个元素或者中间位置的元素作为基准。选择不同的基准元素会影响算法的实际执行效率,但不会影响最终排序结果。
2. 分区操作
分区操作的目标是遍历整个待排序序列,将小于基准元素的元素放到基准左侧,大于基准元素的元素放到基准右侧,最终基准元素会停留在它最终应该处于的位置。这个步骤完成后,基准元素的位置就固定了,不需要再参与后续的排序。
3. 递归处理子序列
完成分区操作后,基准元素左侧和右侧会形成两个独立的子序列,对这两个子序列分别重复执行选择基准、分区、递归的步骤,直到每个子序列只剩下一个元素或者为空,整个序列就完成了排序。
python实现快速排序的完整代码
下面是基于上述逻辑实现的python快速排序代码,代码中包含详细注释说明每一步的作用:
def quick_sort(arr, left, right):
# 递归终止条件:左边界大于等于右边界时,子序列无需排序
if left >= right:
return
# 选择最左侧元素作为基准元素
pivot = arr[left]
i = left
j = right
# 分区操作,调整元素位置
while i < j:
# 从右向左找第一个小于基准的元素
while i < j and arr[j] >= pivot:
j -= 1
# 找到后将元素放到左指针位置
if i < j:
arr[i] = arr[j]
i += 1
# 从左向右找第一个大于基准的元素
while i < j and arr[i] <= pivot:
i += 1
# 找到后将元素放到右指针位置
if i < j:
arr[j] = arr[i]
j -= 1
# 将基准元素放到最终位置
arr[i] = pivot
# 递归处理基准左侧的子序列
quick_sort(arr, left, i - 1)
# 递归处理基准右侧的子序列
quick_sort(arr, i + 1, right)
# 测试代码
test_arr = [3, 6, 8, 2, 1, 9, 4]
print("排序前的数组:", test_arr)
quick_sort(test_arr, 0, len(test_arr) - 1)
print("排序后的数组:", test_arr)
快速排序运作过程示例
以数组[3,6,8,2,1,9,4]为例,快速排序的运作过程如下:
- 第一次选择基准元素3,分区后数组变为
[2,1,3,6,8,9,4],基准3到达最终位置 - 递归处理左侧子序列
[2,1],选择基准2,分区后变为[1,2],基准2到达最终位置 - 递归处理右侧子序列
[6,8,9,4],选择基准6,分区后变为[4,6,8,9],基准6到达最终位置 - 继续递归处理子序列,最终整个数组完成排序,结果为
[1,2,3,4,6,8,9]
快速排序的特点
快速排序的优势在于平均效率很高,不需要额外的存储空间(原地排序),但最坏情况下时间复杂度会退化为O(n²),比如待排序序列已经是有序状态且每次选择第一个元素作为基准的场景。实际使用中可以通过随机选择基准元素或者三数取中法来优化这个问题,提升算法的稳定性。