Go usa el paquete de clasificación para ordenar el mapa

package main
 
import (
	"fmt"
	"sort"
)
 
func main()  {
	test := map[string]int{"wang":1,"liang":4,"lin":2,"dd":2,"haha":10}
	haha := rankByWordCount(test)
	fmt.Println(haha)
	
}
 
 
func rankByWordCount(wordFrequencies map[string]int) PairList{
	pl := make(PairList, len(wordFrequencies))
	i := 0
	for k, v := range wordFrequencies {
		pl[i] = Pair{k, v}
		i++
	}
	//从小到大排序
	//sort.Sort(pl)
	//从大到小排序
	sort.Sort(sort.Reverse(pl))
	return pl
}
 
type Pair struct {
	Key string
	Value int
}
 
type PairList []Pair
 
func (p PairList) Len() int { return len(p) }
func (p PairList) Less(i, j int) bool { return p[i].Value < p[j].Value }
func (p PairList) Swap(i, j int){ p[i], p[j] = p[j], p[i] }

Supongo que te gusta

Origin blog.csdn.net/pulong0748/article/details/122346343
Recomendado
Clasificación