题目
解题
必须原地旋转 意味着 只能交换
旋转应该有多种策略
- 先对角置换
- 再反转
from typing import *
def solution(matrix: List[List[int]]):
n = len(matrix)
# 转置矩阵
for i in range(n):
for j in range(i, n):
matrix[i][j], matrix[j][i] = matrix[j][i], matrix[i][j]
# 反转每一行
for i in range(n):
matrix[i].reverse()
执行过程如下
rotate(matrix)
|
|--transpose(matrix)
| |
| |--for i = 0 to n-1
| | |
| | |--for j = i to n-1
| | | |
| | | |--swap matrix[i][j] with matrix[j][i]
| | |
|
|--reverseRows(matrix)
|
|--for i = 0 to n-1
| |
| |--for j = 0 to n/2
| | |
| | |--swap matrix[i][j] with matrix[i][n-1-j]
| |