码迷,mamicode.com
首页 > 编程语言 > 详细

golang数据结构之快速排序

时间:2019-12-10 17:06:43      阅读:97      评论:0      收藏:0      [点我收藏+]

标签:图片   block   过程   col   auto   inf   quic   info   bsp   

具体过程:黑色标记代表左指针,红色标记代表右指针,蓝色标记代表中间值。(依次从左往向下)

技术图片

 

//QuickSort 快速排序
func QuickSort(left int, right int, arr *[7]int) {
    l := left
    r := right
    pivot := arr[(left+right)/2]
    tmp := 0
    for l < r {
        for arr[l] < pivot {
            l++
        }
        for arr[r] > pivot {
            r--
        }
        if l >= r {
            break
        }
        tmp = arr[l]
        arr[l] = arr[r]
        arr[r] = tmp
        if arr[l] == pivot {
            r--
        }
        if arr[r] == pivot {
            l++
        }
    }
    if l == r {
        l++
        r--
    }
    if left < r {
        QuickSort(left, r, arr)
    }
    if right > l {
        QuickSort(l, right, arr)
    }
}

技术图片

golang数据结构之快速排序

标签:图片   block   过程   col   auto   inf   quic   info   bsp   

原文地址:https://www.cnblogs.com/xiximayou/p/12017445.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!