44

Goで、マップ内のキーをアルファベット順に並べ替える最も簡単な方法は何ですか?これは私がそれを行うことができる最短の方法です:

package main

import "container/vector"
import "fmt"
import "sort"

func main() {
    m := map[string]string {"b":"15", "z":"123123", "x":"sdf", "a":"12"}
    var keys vector.StringVector;
    for k,_ := range ( m ) {
            keys.Push(k)
    }
    sort.Sort( &keys )
    fmt.Printf("%v\n", keys)
}
4

2 に答える 2

56

StringVector を使用して文字列の配列を並べ替えています。オーバーヘッドを最小限に抑えるために、文字列の配列を並べ替えることができます。

package main

import (
    "fmt"
    "sort"
)

func main() {
    m := map[string]string{"b": "15", "z": "123123", "x": "sdf", "a": "12"}
    mk := make([]string, len(m))
    i := 0
    for k, _ := range m {
        mk[i] = k
        i++
    }
    sort.Strings(mk)
    fmt.Println(mk)
}

出力:

[a b x z]
于 2010-01-10T23:59:09.977 に答える
16

それは最もエレガントな方法です:

package main

import (
    "fmt"
    "sort"
)

func main() {
    m := map[string]string{"b": "15", "z": "123123", "x": "sdf", "a": "12"}
    keys := make([]string, 0, len(m))
    for key := range m {
        keys = append(keys, key)
    }
    sort.Strings(keys)
    fmt.Println(keys)
}
于 2014-06-08T07:55:48.640 に答える