duanluanlang8501 2017-03-06 15:32
浏览 2
已采纳

朗朗排序2D阵列

I want to sort a two dimensional array in Go. Can anyone please suggest how I can go about this?

For example If I have,

var matrix [3][3]int{
  {2,3,1},
  {6,3,5},
  {1,4,9}
}

Then is there something like,

sort.Sort(matrix)
  • 写回答

1条回答 默认 最新

  • dqpd4268 2017-03-06 15:51
    关注

    You have to define how to sort this type yourself. You can either create the necessary methods to use the sort.Sort interface, using a pointer as necessary to mutate the array values: 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)
    }
    

    Or use the sort.Slice function, converting matrix to a slice and providing an appropriate less function: 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)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染