반응형
Map [string] int를 값으로 정렬하는 방법은 무엇입니까?
이 코드 블록이 주어지면
map[string]int {"hello":10, "foo":20, "bar":20}
인쇄하고 싶습니다
foo, 20
bar, 20
hello, 10
높은 순으로
감사!
Andrew Gerrand의 Golang-nuts에서 답을 찾았습니다.
len / less / swap 함수를 작성하여 정렬 인터페이스를 구현할 수 있습니다.
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(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] }
원본 게시물은 여기 https://groups.google.com/forum/#!topic/golang-nuts/FT7cjmcL7gw에서 찾으십시오.
go 1.8에 새로운 sort.Slice 함수가 있으므로 이제 더 간단합니다.
package main
import (
"fmt"
"sort"
)
func main() {
m := map[string]int{
"something": 10,
"yo": 20,
"blah": 20,
}
type kv struct {
Key string
Value int
}
var ss []kv
for k, v := range m {
ss = append(ss, kv{k, v})
}
sort.Slice(ss, func(i, j int) bool {
return ss[i].Value > ss[j].Value
})
for _, kv := range ss {
fmt.Printf("%s, %d\n", kv.Key, kv.Value)
}
}
https://play.golang.org/p/y1_WBENH4N
예를 들면 :
package main
import (
"fmt"
"sort"
)
func main() {
m := map[string]int{"hello": 10, "foo": 20, "bar": 20}
n := map[int][]string{}
var a []int
for k, v := range m {
n[v] = append(n[v], k)
}
for k := range n {
a = append(a, k)
}
sort.Sort(sort.Reverse(sort.IntSlice(a)))
for _, k := range a {
for _, s := range n[k] {
fmt.Printf("%s, %d\n", s, k)
}
}
}
산출:
foo, 20
bar, 20
hello, 10
먼저 값별로 키를 정렬 한 다음 맵을 반복합니다.
package main
import (
"fmt"
"sort"
)
func main() {
counts := map[string]int{"hello": 10, "foo": 20, "bar": 20}
keys := make([]string, 0, len(counts))
for key := range counts {
keys = append(keys, key)
}
sort.Slice(keys, func(i, j int) bool { return counts[keys[i]] > counts[keys[j]] })
for _, key := range keys {
fmt.Printf("%s, %d\n", key, counts[key])
}
}
참고 URL : https://stackoverflow.com/questions/18695346/how-to-sort-a-mapstringint-by-its-values
반응형
'code' 카테고리의 다른 글
JAX-RS의 필수 @QueryParam (및 부재시 수행 할 작업) (0) | 2020.11.17 |
---|---|
동일한 스크립트로 제출시 HTML 양식에서 PHP로 이메일 보내기 (0) | 2020.11.17 |
독일어 키보드의 줄 주석 단축키 (0) | 2020.11.17 |
API 23의 Android 권한 일반 권한 및 위험한 권한 목록? (0) | 2020.11.17 |
텍스트 영역 아래의 추가 공간, 브라우저에 따라 다름 (0) | 2020.11.16 |