Go lang 对二维数组进行排序

Shi*_*han 9 arrays go

我想在 Go 中对二维数组进行排序。谁能建议我该怎么做?

例如如果我有,

var matrix [3][3]int{
  {2,3,1},
  {6,3,5},
  {1,4,9}
}
Run Code Online (Sandbox Code Playgroud)

那么有没有类似的东西,

sort.Sort(matrix)
Run Code Online (Sandbox Code Playgroud)

Jim*_*imB 17

您必须自己定义如何对这种类型进行排序。您可以创建必要的方法来使用该sort.Sort接口,根据需要使用指针来改变数组值: https: //play.golang.org/p/thdf-k2k3o

type Matrix [3][3]int

func (m Matrix) Len() int { return len(m) }
func (m Matrix) Less(i, j int) bool {
    for x := range m[i] {
        if m[i][x] == m[j][x] {
            continue
        }
        return m[i][x] < m[j][x]
    }
    return false
}

func (m *Matrix) Swap(i, j int) { m[i], m[j] = m[j], m[i] }
func main() {
    m := Matrix(matrix)
    sort.Sort(&m)
}
Run Code Online (Sandbox Code Playgroud)

或者使用该sort.Slice函数,转换matrix为切片并提供适当的 less 函数: https: //play.golang.org/p/4hrghm9gib

sort.Slice(matrix[:], func(i, j int) bool {
    for x := range matrix[i] {
        if matrix[i][x] == matrix[j][x] {
            continue
        }
        return matrix[i][x] < matrix[j][x]
    }
    return false
})

fmt.Println(matrix)
Run Code Online (Sandbox Code Playgroud)


mou*_*kat 12

考虑你有 am*n 矩阵,并且你想根据第 k 列进行排序

sort.SliceStable(rangearray, func(i, j int) bool {
        return rangearray[i][k] < rangearray[j][k]
})
Run Code Online (Sandbox Code Playgroud)

以同样的方式,你想要对 m*n 矩阵进行排序,并且你想要基于第 k 行进行排序

sort.SliceStable(rangearray, func(i, j int) bool {
        return rangearray[k][i] < rangearray[k][j]
})
Run Code Online (Sandbox Code Playgroud)