- 快速排序由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。
利用分治法可将快速排序的分为三步:
- 在数据集之中,选择一个元素作为”基准”(pivot)。
- 所有小于”基准”的元素,都移到”基准”的左边;所有大于”基准”的元素,都移到”基准”的右边。这个操作称为分区 (partition) 操作,分区操作结束后,基准元素所处的位置就是最终排序后它的位置。
- 对”基准”左边和右边的两个子集,不断重复第一步和第二步,直到所有子集只剩下一个元素为止。
快速排序平均时间复杂度为O(n log n)
,最坏情况为O(n2)
,不稳定排序。
这里实现了两种方式的快排,第一种是单路的,实现代码如下:
1 | func partition(sortArray []int, left, right int) int { |
第二种是双路的:
1 | unc partition2(arr []int,left,right int)(p int) { |
测试代码如下:
1 | import ("fmt") |
BUT!
要表达快排的思想,还是使用Python比较透彻:
1 | def quickSort(array): |
是不是将快排的分治思想表达地淋漓尽致,简洁美观。
End!