算法思想:
像归并排序一样,快速排序也是基于分治模式的。对于一个子数组A[p..r]排序的分治过程有如下3个步骤:
分解:数组被划分成两个子数组A[p..q-1]和A[q+1..r],使得A[p..q-1]中的元素都小于等于A[q],而且,小于等于A[q+1..r]中的元素。下标q也在这个划分过程中进行计算。
解决:通过递归调用快速排序,对子数组A[p..q-1]和A[q+1..r]排序。
合并:因为两个子数组是就地排序的,将它们的合并不需要操作:整个数组A[p..r]已排序。
算法代码:
算法结果:
算法复杂度:O(nlgn)