在Go 中按Map 的值對Map 進行排序
在Go 中按Map 的值對Map 進行排序需要排序介面的自訂實作。這是一個實作PairList 類型並定義排序所需函數的解:
<br>funcrankByWordCount(wordFrequencies map[string]int) PairList {<br> pl := make(PairList, lenake(PairList, lenake(PairList, lenake(PairList, lenake(PairList, lenake(PairList, lenake(PairList, lenake(PairList, lenake(PairList, len) (wordFrequencies))<br> i := 0<br> 對於k, v := range wordFrequencies {<pre class="brush:php;toolbar:false">pl[i] = Pair{k, v} i++
}
sort.Sort(sort.Reverse(pl))
return pl
}
type Pair struct
鍵字串
值int
}
type PairList []Pair
func (p PairList) Len() int { return len(p) }
func (p PairList) Less(i , j int) bool { return p[i].Value func (p PairList) Swap(i, j int){ p[i], p[j] = p[j], p[i] }
使用rankByWordCount函數,您可以將地圖排序為如下:
<br>wordFrequencies := map[string]int{<br> "hello": 10,<br> "foo": 20,<br> "bar": 20 ,<br>}<p>排序對:= rankByWordCount(wordFrequencies)</p>排序對:= rankByWordCount(wordFrequencies)<p><br> _ ,pair := rangesortedPairs {<br>fmt.Println(pair.Key, pair.Value)<br>}</p>
<br>foo 20<br>bar 20<br>hello 10
以上是如何按值對 Go 地圖進行排序?的詳細內容。更多資訊請關注PHP中文網其他相關文章!