go 快排

package main

import "fmt"

func main() {
    testSort()
}

func testSort() {
    slicData := []int{3, 2, 4, 5, 6, 6, 7, 8, 3, 2, 1}
    fmt.Println("brfore", slicData)

    quickSortRefer(slicData, 0, len(slicData)-1)
    fmt.Println("brfore", slicData)
}

func quickSortRefer(slicData []int, strt int, end int) {
    l := strt
    r := end
    if r > l {
        mid := slicData[l]
        for l < r {
            for (l < r) && mid <= slicData[r] {
                r--
            }
            slicData[l] = slicData[r]
            slicData[r] = mid

            for (l < r) && mid >= slicData[l] {
                l++
            }
            slicData[r] = slicData[l]
            slicData[l] = mid

        }
        quickSortRefer(slicData, 0, l-1)
        quickSortRefer(slicData, l+1, end)
    }
}

func test1() {
    list := []int{1, 2, 3}
    var res *int
    for k, v := range list {
        if v == 1 {
            fmt.Println("33333333", k, v)
            res = &list[k]
        }
    }
    fmt.Println("33333333", *res)
}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容