Golang 找出转置
在本文中,我们将编写一个 Go 语言程序来找出矩阵的转置。矩阵是一组按行和列排列的数字,是一个二维数组。
找到矩阵的转置
以下代码示例演示了如何找到矩阵的转置。
步骤
第一步 − 导入 fmt 包。
第二步 − 调用 main() 函数。
第三步 − 初始化一个名为 matrixA 和 matrix 的二维数组,并在其中存储元素。
第四步 − 在屏幕上打印矩阵。
第五步 − 通过使用 for 循环遍历矩阵来找到这些矩阵的转置,并通过将矩阵的每一行改为列来创建一个新矩阵。
第六步 − 一旦我们遍历了矩阵,就在屏幕上打印出新形成的矩阵。
第七步 − 重复此过程以找到第二个矩阵的转置并在屏幕上打印出来。
示例
package main
import (
"fmt"
)
func main() {
var i, j int
var transposeMat [3][3]int
matrixA := [3][3]int{
{0, 1, 2},
{4, 5, 6},
{8, 9, 10},
}
fmt.Println("The first matrix is:")
for i = 0; i < 3; i++ {
for j = 0; j < 3; j++ {
fmt.Print(matrixA[i][j], "\t")
}
fmt.Println()
}
fmt.Println()
for i = 0; i < 3; i++ {
for j = 0; j < 3; j++ {
transposeMat[j][i] = matrixA[i][j]
}
}
fmt.Println("The transpose of matrix is:")
for i = 0; i < 3; i++ {
for j = 0; j < 3; j++ {
fmt.Print(transposeMat[i][j], "\t")
}
fmt.Println()
}
}
输出
The first matrix is:
0 1 2
4 5 6
8 9 10
The transpose of matrix is:
0 4 8
1 5 9
2 6 10
使用range函数查找矩阵的转置
现在让我们来看看在Go编程语言中查找矩阵的转置的另一种方法。
步骤
步骤1 - 导入fmt包。
步骤2 - 调用main()函数。
步骤3 - 初始化一个名为matrixA的二维数组,并存储其中的元素。使用fmt.Println()函数在屏幕上打印此矩阵。
步骤4 - 使用range函数迭代矩阵,通过将矩阵的每一行更改为列来创建一个新矩阵。
步骤5 - 一旦我们遍历了整个矩阵,就在屏幕上打印出形成的新矩阵。
示例
package main
import (
"fmt"
)
func main() {
var i, j int
var transposeMat [3][3]int
matrixA := [3][3]int{
{0, 1, 2},
{4, 5, 6},
{8, 9, 10},
}
fmt.Println("The first matrix is:")
for i = 0; i < 3; i++ {
for j = 0; j < 3; j++ {
fmt.Print(matrixA[i][j], "\t")
}
fmt.Println()
}
fmt.Println()
for i, rows := range matrixA {
for j := range rows {
transposeMat[j][i] = matrixA[i][j]
}
}
fmt.Println("The transpose of matrix, matrixA is:")
for i, rows := range matrixA {
for j := range rows {
fmt.Print(transposeMat[i][j], "\t")
}
fmt.Println()
}
fmt.Println()
}
输出
The first matrix is:
0 1 2
4 5 6
8 9 10
The transpose of matrix, matrixA is:
0 4 8
1 5 9
2 6 10
结论
我们成功地编译和执行了一个golang程序,用于找到矩阵的转置,并附带了示例。