golang sort 工具包的用法

基本類型 int 、 float64 和 string 的排序
go 分別提供了 sort.Ints() 、 sort.Float64s() 和 sort.Strings() 函數(shù)

    ints := []int{2, 4, 3, 5, 7, 6, 9, 8, 1, 0}
    sort.Ints(ints)
    fmt.Println(ints) // [0 1 2 3 4 5 6 7 8 9]

如果像要降序,則先需綁定以下3個方法

Paste_Image.png

sort 包下的三個類型 IntSlice 、 Float64Slice 、 StringSlice 分別實現(xiàn)了這三個方法, 對應(yīng)排序的是 [] int 、 [] float64 和 [] string, 如果期望逆序排序, 只需要將對應(yīng)的 Less 函數(shù)簡單修改一下即可

    ints := []int{2, 4, 3, 5, 7, 6, 9, 8, 1, 0}
    sort.Sort(sort.Reverse(sort.IntSlice(ints)))
    fmt.Println(ints) // [9 8 7 6 5 4 3 2 1 0]

<h3>結(jié)構(gòu)體類型的排序</h3>

type Person struct {
    Age int32
}

type Persons []*Person

func (this Persons) Len() int {
    return len(this)
}

func (this Persons) Swap(i, j int) {
    this[i], this[j] = this[j], this[i]
}

func (this Persons) Less(i, j int) bool {
    return this[i].Age > this[j].Age
}

func SortStruct() {
    p1 := &Person{1}
    p2 := &Person{4}
    p3 := &Person{2}
    list := make([]*Person, 0)
    list = append(list, p1, p2, p3) //需要排序的數(shù)組
    persons := Persons{} 
    persons = list
    sort.Sort(persons) //通過重寫的 less,用age 屬性進(jìn)行排序
    for _, v := range persons {
        fmt.Println(v.Age)
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,734評論 18 399
  • 閉包是功能性自包含模塊,可以在代碼中被傳遞和使用。Swift中的閉包與 C 和 Objective-C中的 blo...
    AirZilong閱讀 387評論 0 2
  • 首頁 資訊 文章 資源 小組 相親 登錄 注冊 首頁 最新文章 IT 職場 前端 后端 移動端 數(shù)據(jù)庫 運維 其他...
    Helen_Cat閱讀 4,153評論 1 10
  • 人生的意義,每個人可能都有自己的答案。 寫這個題目,感覺自己壓力好大,可是又鼓起了勇氣,寫了下來。不妥之處,還請大...
    陽光一風(fēng)箏閱讀 553評論 2 7
  • 墻 文/厲雄(西班牙) 夏天的綠墻,總是自顧自地蔓延 它有自己的秩序,不增不減 夏天的風(fēng),用自己的味道 與綠墻交頭...
    厲雄閱讀 174評論 0 1

友情鏈接更多精彩內(nèi)容