首页 > 其他 > 详细

sort.Sort() interface in GoLang

时间:2021-04-20 20:50:57      阅读:16      评论:0      收藏:0      [点我收藏+]

 

 

原文:https://medium.com/@kdnotes/sort-sort-interface-in-golang-1d263d96956d

 

package main
import (
 "fmt"
 "sort"
 //"unicode/utf8"
)
type P struct {
 name string
 age  int
}
type nameSortedPs []P
func (a nameSortedPs) Len() int {
 return len(a)
}
func (a nameSortedPs) Less(i, j int) bool {
 //iRune, _ := utf8.DecodeRuneInString(a[i].name)
 //jRune, _ := utf8.DecodeRuneInString(a[j].name)
 //return int32(iRune) < int32(jRune)
  return a[i].age > a[j].age
}
func (a nameSortedPs) Swap(i, j int) {
 a[i], a[j] = a[j], a[i]
}
func main() {
 groupA := []P{
  {"gold", 14}, {"dave", 18}, {"kane", 12}, {"rain", 34},
 }
 sort.Sort(nameSortedPs(groupA))
fmt.Println(groupA)
}

  技术分享图片

 

 

------------------------------

Sorting in Go

sort.Ints
sort.Float64s
sort.Strings
names := []string{“jane”, “dave”, “mike”, “kane”, “rain”}
sort.Strings(names)
fmt.Println(names)
group := []struct {
name string
age int
}{
{“Gold”, 14}, {“dave”, 18}, {“kane”, 12}, {“rain”, 34},
}sort.Slice(group, func(i, j int) bool {
return group[i].age < group[j].age
})fmt.Println(group)

The Sort interface

type Interface interface{
Len() int
Less (i , j) bool
Swap(i , j int)
}
import (
"fmt"
"sort"
"unicode/utf8"
)type P struct {
name string
age int
}type nameSortedPs []Pfunc (a nameSortedPs) Len() int {
return len(a)
}func (a nameSortedPs) Less(i, j int) bool {
iRune, _ := utf8.DecodeRuneInString(a[i].name)
jRune, _ := utf8.DecodeRuneInString(a[j].name)
return int32(iRune) < int32(jRune)
}func (a nameSortedPs) Swap(i, j int) {
a[i], a[j] = a[j], a[i]
}func main() {
groupA := []P{
{"gold", 14}, {"dave", 18}, {"kane", 12}, {"rain", 34},
}
sort.Sort(nameSortedPs(groupA))fmt.Println(groupA)
}

sort.Sort() interface in GoLang

原文:https://www.cnblogs.com/oxspirt/p/14682011.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!