Простой способ получить ключи на карте в алфавитном порядке - PullRequest
40 голосов
/ 10 января 2010

В 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)
}

Ответы [ 2 ]

53 голосов
/ 11 января 2010

Вы сортируете массив строк, используя 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]
13 голосов
/ 08 июня 2014

Это был бы самый элегантный метод:

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)
}
...