【Go】sort 包:sort.Ints()、sort.Strings()、sort.Slice()(转载)

文章目录
一、sort 包说明
二、sort.Ints()、sort.Strings()
三、sort.Slice()
参考链接
一、sort 包说明
这个包是一个 golang 内置的 切片排序 包,除了排序外还有一些其它的方法,可以对一些基本的可以比较大小的类型的切片进行排序,也可以通过实现排序接口的几个特定方法实现自定义排序。

二、sort.Ints()、sort.Strings()
可以使用sort.Ints()、sort.Strings()等内置方法对基本数据类型的切片进行排序。

package main

import (
    "fmt"
    "sort"
)

func main() {
    ints := []int{3, 2, 1}
    strs := []string{"c", "d", "a"}
    sort.Strings(strs)
    sort.Ints(ints)
    fmt.Printf("%v\n", ints)
    fmt.Printf("%v\n", strs)
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
输出结果:

[1 2 3]
[a c d]
1
2
注意:
sort.Ints()、sort.Strings() 等方法都是按升序排序的,如果我们希望按降序排序就需要我们自定义排序规则。

三、sort.Slice()
Go 1.8之后的版本,在 sort 包中提供了 sort.Slice() 函数进行更为简便的排序方法。

sort.Slice() 函数只要求传入需要排序的数据,以及一个排序时对元素的回调函数。

用法:

sort.Slice(tmp,func(i,j int){  //tmp是要排序的切片
        return tmp[i]<tmp[j]
    })
1
2
3
实例:

package main

import (
    "fmt"
    "sort"
)

func main() {
    a := []int{6, 3, 9, 8, 1, 2, 5, 7}
    sort.Slice(a, func(i, j int) bool {
        return a[i] > a[j]
    })
    fmt.Println(a)
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
输出结果:

[9 8 7 6 5 3 2 1]
1
参考链接
golang sort包的使用(一)
Go语言sort包排序
————————————————
版权声明:本文为CSDN博主「想变厉害的大白菜」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_44211968/article/details/124639964

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值