快速排序

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了快速排序相关的知识,希望对你有一定的参考价值。

一、什么是快速排序?
  把一个无序的数组,第一趟排序后将数组分隔成两部分,若把前半部分和后半部分的相交元素称为中间元素。前半部分的所有元素小于中间元素,后半部分的所有元素大于中间元素。再对前半部分和后半部分分别进行上述递归操作。最终得到一个有序数组。

 

二、如何进行快速排序?

  最近正好我在学习Go语言,决定用Go语言自己描述一遍。

 

func QuickSort(arr []int) {
    if len(arr) <= 1 {
        return
    }

    mid, i := arr[0], 1
    left, right := 0, len(arr)-1

    for left < right {
        if arr[i] > mid {
            arr[i], arr[right] = arr[right], arr[i]
            right--
        } else {
            arr[i], arr[left] = arr[left], arr[i]
            left++
            i++
        }
    }

    arr[left] = mid
    QuickSort(arr[:left])
    QuickSort(arr[left+1:])
}

 

  

 

  但是,上面的代码会存在交换次数过多的问题,这个问题可以使用下面代码进行优化。

 

func QuickSort(arr []int) {
    if len(arr) <= 1 {
        return
    }

    mid := arr[0]
    left, right := 0, len(arr)-1

    for left < right {
        if left < right && arr[right] >= mid  {
            right--
        }

        arr[left++] = arr[right]

        if left < right &&  arr[left] <= mid {
            left++
        }

        arr[right--] = arr[left]
    }

    arr[left] = mid
    QuickSort(arr[:left])
    QuickSort(arr[left+1:])
}

 

 

 

 

 

以上是关于快速排序的主要内容,如果未能解决你的问题,请参考以下文章

算法排序之堆排序

前端开发工具vscode如何快速生成代码片段

前端开发工具vscode如何快速生成代码片段

如何使用sublime代码片段快速输入PHP头部版本声明

代码片段如何使用CSS来快速定义多彩光标

vs2003:快速片段工具