快速排序(QuickSort) 作为最流行的排序算法之一,又有非常出色的性能,被广大的编程语言作为标准库默认排序方法。
快速排序的设计思想是一个很好的分治法(divide-and-conquer) 的实例,理解他的实现原理将有助于我们在实际生产过程中设计自己的解决问题的算法。最直接的,很多算法题目需要使用到类似的思想。
先贴代码(Go):
func quickSort(nums []int, l, r int) {
//[l,r]
if l < r {
m := partition(nums, l, r)
quickSort(nums, l, m