一、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]
[a c d]
注意:
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]
})
实例:
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)
}
输出结果:
[9 8 7 6 5 3 2 1]
参考链接
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/118923.html