快速排序(golang实现)

封装成函数:

//快速排序
func QuickSort(s []int) {
    sort(s, 0, len(s)-1)
}
 
func sort(s []int, lo, hi int) {
    if lo >= hi {
        return
    }
    k := partition(s, lo, hi)
    sort(s, lo, k)
    sort(s, k+1, hi)
}
 
func partition(s []int, lo, hi int) int {
    i, j := lo, hi+1 //将lo作为中间值
    for {
        for {
            i++
            if i == hi || s[i] > s[lo] {
                break
            }
        }
        for {
            j--
            if j == lo || s[j] <= s[lo] {
                break
            }
        }
        if i >= j {
            break
        }
        swap(s, i, j)
    }
    swap(s, lo, j)
    return j
}
 
func swap(s []int, i int, j int) {
    s[i], s[j] = s[j], s[i]
}

测试:

s := []int{9, 0, 6, 5, 8, 2, 1, 7, 4, 3}
fmt.Println(s)
QuickSort(s)
fmt.Println(s)

输出:
[9 0 6 5 8 2 1 7 4 3]
[0 1 2 3 4 5 6 7 8 9]

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 临近睡觉前,我用常喝酒的四方杯去倒一杯茶,毫无征兆的,它却倔强的裂开了!留个杯底,让我无法释怀! 我也真是,好好的...
    猫浪人阅读 516评论 0 2
  • -1- 2012年12月底,新疆乌鲁木齐,一个来自山东的小语种大专生,跨越千山万水坐上了发往...
    哭瞎眼阅读 6,517评论 4 9
  • 终于要启程前往湛江了,早早起床,冥想儿子香香的的沉睡,悄声洗漱轻声关上家门,一身轻松的赶往车站,不想车站附近修路,...
    赵钰淇阅读 402评论 0 0
  • 1 C语言中 在C语言中,static有三个明显作用: 函数体内static变量,不会随函数结束而消亡。再次调用该...
    saviochen阅读 1,914评论 0 4

友情链接更多精彩内容