题解 | #顺时针旋转矩阵#

顺时针旋转矩阵

http://www.nowcoder.com/practice/2e95333fbdd4451395066957e24909cc


public class Solution {
    //基本要求:增加空间复杂度
    public int[][] rotateMatrix_base(int[][] mat, int n) {
        
        int[][] rotate = new int[n][n];
        
        for(int i=0; i<n; i++){
            for(int j=0; j<n; j++){
                rotate[j][n-1-i] = mat[i][j];
            }
        }
        return rotate;
    }
    //进阶:直接在原矩阵上修改
    public int[][] rotateMatrix(int[][] mat, int n) {
        //对角翻转
        for(int i=0; i<n; i++){
            for(int j=0; j<i; j++){
                int tmp = mat[i][j];
                mat[i][j] = mat[j][i];
                mat[j][i] = tmp;
            }
        }
        //左右翻转
        for(int i=0; i<n; i++){
            for(int j=0; j<n/2; j++){
                int tmp = mat[i][j];
                mat[i][j] = mat[i][n-1-j];
                mat[i][n-1-j] = tmp;
            }
        }
        return mat;
    }
}
全部评论

相关推荐

06-28 22:48
已编辑
广东金融学院 Java
小浪_Coding:学院本+这俩项目不是buff叠满了嘛
点赞 评论 收藏
分享
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-08 12:05
俺不中了,BOSS遇到了一个hr,我觉得我咨询的问题都很正常吧,然后直接就被拒绝了???
恶龙战士:你问的太多了,要不就整理成一段话直接问他,一个一个问不太好
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务