golang实现旋转二维数组

发布时间:2024-12-22 13:41:19

旋转二维数组的实现

在Golang中,有时候我们需要对二维数组进行旋转操作,也就是将二维数组按照某个方向进行顺时针或逆时针旋转。本文将介绍如何使用Golang来实现旋转二维数组的操作。

方法一:使用额外的二维数组

首先,我们可以创建一个新的二维数组,然后将原数组中的每个元素根据旋转规则放入新数组中。下面的示例代码实现了顺时针旋转一个二维数组90度:

```go func rotateArray(matrix [][]int) [][]int { n := len(matrix) rotatedMatrix := make([][]int, n) for i := 0; i < n; i++ { rotatedMatrix[i] = make([]int, n) } for i := 0; i < n; i++ { for j := 0; j < n; j++ { rotatedMatrix[j][n-i-1] = matrix[i][j] } } return rotatedMatrix } ```

上述代码中,首先我们获取原始二维数组的大小n,并创建一个和原数组相同大小的新数组rotatedMatrix。然后,我们遍历原数组的每一个元素,将其按照旋转规则放入新数组中。最后,返回新数组。

方法二:原地旋转

除了使用额外的二维数组,我们还可以在原数组上进行原地旋转操作。原地旋转意味着我们只需要使用常数级别的额外空间,而不需要创建新的数组。

顺时针旋转

下面的示例代码实现了顺时针旋转一个二维数组90度:

```go func rotateArray(matrix [][]int) { n := len(matrix) // 先沿对角线翻转 for i := 0; i < n; i++ { for j := i + 1; j < n; j++ { matrix[i][j], matrix[j][i] = matrix[j][i], matrix[i][j] } } // 再按行翻转 for i := 0; i < n; i++ { for j := 0; j < n/2; j++ { matrix[i][j], matrix[i][n-j-1] = matrix[i][n-j-1], matrix[i][j] } } } ```

上述代码中,我们首先沿对角线进行翻转操作,即将第i行第j列的元素与第j行第i列的元素进行交换。然后,再按行进行翻转操作,即将每一行的元素进行左右两侧的交换。这样就完成了顺时针旋转90度的操作。

逆时针旋转

逆时针旋转一个二维数组90度可以通过先顺时针旋转270度再顺时针旋转90度来实现:

```go func rotateArray(matrix [][]int) { rotateArray(matrix) rotateArray(matrix) rotateArray(matrix) } ```

总结

本文介绍了使用Golang实现旋转二维数组的方法。我们可以选择使用额外的二维数组或者在原数组上进行原地旋转操作。无论选择哪种方法,都可以有效地实现旋转二维数组的功能。

相关推荐