登录
首页 >  Golang >  Go问答

golang排序切片升序或降序

来源:Golang技术栈

时间:2023-03-22 19:33:26 207浏览 收藏

今日不肯埋头,明日何以抬头!每日一句努力自己的话哈哈~哈喽,今天我将给大家带来一篇《golang排序切片升序或降序》,主要内容是讲解golang等等,感兴趣的朋友可以收藏或者有更好的建议在评论提出,我都会认真看的!大家一起进步,一起学习!

问题内容

我需要对来自 3rdparty 包的类型的一部分进行排序。根据某些条件,顺序必须是升序或降序。

我想出的解决方案是:

type fooAscending []foo

func (v fooAscending) Len() int           { return len(v) }
func (v fooAscending) Swap(i, j int)      { v[i], v[j] = v[j], v[i] }
func (v fooAscending) Less(i, j int) bool { return v[i].Amount  v[j].Amount }

if someCondition {
    sort.Sort(fooAscending(array))
} else {
    sort.Sort(fooDescending(array))
}

有一个更好的方法吗。这个任务的 13 行代码,其中大部分是重复的,似乎有点太多了。

正确答案

从 Go 1.8 开始,有一种更简单的方法来对切片进行排序,不需要您定义新类型。您只需将匿名函数传递给该sort.Slice函数。

a := []int{5, 3, 4, 7, 8, 9}
sort.Slice(a, func(i, j int) bool {
    return a[i] 

这将按升序排序,如果您想要相反,只需a[i] > a[j]在匿名函数中编写即可。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:Golang技术栈 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>