arrays - 无法使用 Golang 交换二维数组 slice 的元素

标签 arrays matrix go slice

我正在尝试编写一个简单的函数来转置方阵(即交换列和行)。这是有问题的功能:

func Transpose(a [][]bool) {
    for i := 0; i < len(a); i++ {
        for j := 0; j < len(a[i]); j++ {
            a[i][j], a[j][i] = a[j][i], a[i][j]
        }
    }
}

好像不行。如果我运行这个函数

func TestTranspose(t *testing.T) {
    a := make([][]bool, 3)
    a[0] = []bool{true, true, true}
    a[1] = []bool{false, true, false}
    a[2] = []bool{true, true, true}

    fmt.Println(BoolArrayViz(a))

    Transpose(a)

    fmt.Println(BoolArrayViz(a))
}

它给出以下输出(BoolArrayViz 简单地将 bool 打印为 '*' 如果 true ' ' 如果 false):

***
 * 
***

***
 * 
***

我相信这与指针和我传递 slice 的事实有关。任何帮助表示赞赏!

最佳答案

您的转置逻辑不正确(您转置了两次),
请参阅此工作测试示例(不使用交换来演示这个想法):

package main

import "fmt"

func Transpose(a [][]bool) {
    n := len(a)
    b := make([][]bool, n)
    for i := 0; i < n; i++ {
        b[i] = make([]bool, n)
        for j := 0; j < n; j++ {
            b[i][j] = a[j][i]
        }
    }
    copy(a, b)
}
func main() {
    a := [][]bool{
        []bool{true, true, true},
        []bool{false, true, false},
        []bool{true, true, true},
    }
    BoolArrayViz(a)
    Transpose(a)
    BoolArrayViz(a)
}

func BoolArrayViz(a [][]bool) {
    n := len(a)
    for i := 0; i < n; i++ {
        for j := 0; j < n; j++ {
            if a[i][j] {
                fmt.Printf("*")
            } else {
                fmt.Printf(" ")
            }
        }
        fmt.Println()
    }
    fmt.Println()
}

输出:

***
 * 
***

* *
***
* *

使用交换(内部循环,j 应该从 i+1 而不是 0 开始):

package main

import "fmt"

func Transpose(a [][]bool) {
    n := len(a)
    for i := 0; i < n; i++ {
        for j := i + 1; j < n; j++ {
            a[i][j], a[j][i] = a[j][i], a[i][j]
        }
    }
}
func main() {
    a := [][]bool{
        []bool{true, true, true},
        []bool{false, true, false},
        []bool{true, true, true},
    }
    BoolArrayViz(a)
    Transpose(a)
    BoolArrayViz(a)
}

func BoolArrayViz(a [][]bool) {
    n := len(a)
    for i := 0; i < n; i++ {
        for j := 0; j < n; j++ {
            if a[i][j] {
                fmt.Printf("*")
            } else {
                fmt.Printf(" ")
            }
        }
        fmt.Println()
    }
    fmt.Println()
}

关于arrays - 无法使用 Golang 交换二维数组 slice 的元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38297882/

相关文章:

java - 求 int 数组的总和 - 忽略 6 和 7 之间的所有数字(含 6 和 7)

objective-c - 从 json 数据填充类

c++ - 重载运算符 []

windows - 32 位 Go Binary 需要提权,64 位不需要

caching - GroupCache 是否支持像 memcached delete 这样的显式缓存逐出?为什么?

arrays - 变量作为 for 循环中的标记

javascript - 搜索列并返回嵌套数组中的行元素

在 block 矩阵的对角部分重复 block 矩阵多次,非对角 block 全部为零矩阵?

arrays - 如何对所有左上角的矩阵元素求和?

go - 测试使用var声明来模拟结果的函数