sorting - golang排序 slice 升序或降序

标签 sorting go

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

我想出的解决办法是:

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 }

type fooDescending []foo

func (v fooDescending) Len() int           { return len(v) }
func (v fooDescending) Swap(i, j int)      { v[i], v[j] = v[j], v[i] }
func (v fooDescending) 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 开始,有一种更简单的方法可以对 slice 进行排序,而无需您定义新类型。您只需将匿名函数传递给 sort.Slice 函数。

a := []int{5, 3, 4, 7, 8, 9}
sort.Slice(a, func(i, j int) bool {
    return a[i] < a[j]
})
for _, v := range a {
    fmt.Println(v)
}

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

关于sorting - golang排序 slice 升序或降序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37695209/

相关文章:

MySQL按数组值排序

Go Lang 工作区重复包名称可执行冲突

regex - 使用 Golang 正则表达式查找一个整数后跟一个字符串

转到 html/模板 : test equality of two dot variables

c - 排序并从 c 中的 int 数组中删除重复项

algorithm - 查找以随意方式存储的连续增加的子序列

php - 如何用 PHP 对数组进行排序,忽略开头的冠词 (a, an, the)?

php - 对可能包含日期和缩写月份名称的字符串数组进行排序

go - 从 slice 中删除项目

postgresql - 我应该如何将Postgres日期类型分配给变量