48. 旋转图像

示例 1:给定一个 n × n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。Grab考过
你必须在 原地 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。
image.png

  1. //先水平翻转,再对角线翻转,时间On^2,空间O1
  2. func rotate(matrix [][]int) {
  3. n := len(matrix)
  4. for i := 0; i < n/2; i++ {
  5. matrix[i], matrix[n-1-i] = matrix[n-1-i], matrix[i]
  6. }
  7. for i := 0; i < n; i++ {
  8. for j := 0; j < i; j++ {
  9. matrix[i][j],matrix[j][i] = matrix[j][i], matrix[i][j]
  10. }
  11. }
  12. }