思路:
顺时针旋转90度
- 先按照主对角翻转
- 然后按照竖中线翻转
代码:
class Solution {
public:
void rotate(vector<vector<int>>& matrix) {
int n=matrix.size();
//顺时针旋转90度
//1 。 先按照主对角翻转
//2 。 然后按照竖中线翻转
for(int i=0;i<n;i++){
//只枚举左下三角即可
for(int j=0;j<i;j++){
swap(matrix[i][j],matrix[j][i]);
}
}
for(int i=0;i<n;i++){
for(int j=0,k=n-1;j<k;j++,k--){
swap(matrix[i][j],matrix[i][k]);
}
}
}
};
评论区