美文网首页
Rotate Matrix

Rotate Matrix

作者: Wenyue_offer | 来源:发表于2017-09-14 08:08 被阅读0次
Screen Shot 2017-09-13 at 17.03.33.png
public class Solution {
    public static int[][] rotate(int[][] matrix, int flag)
    {
        if(matrix == null || matrix.length == 0) return matrix;
        int m = matrix.length, n = matrix[0].length;
        int[][] res = new int[n][m];
        for(int i = 0; i < m; i++)
        {
            for(int j = 0; j < n; j++) res[j][i] = matrix[i][j];
        }
        if(flag == 1)
        {
            for(int i = 0; i < n; i++)
            {
                for(int j = 0; j < m / 2; j++)
                {
                    int tmp = res[i][j];
                    res[i][j] = res[i][m - 1 - j];
                    res[i][m - 1 - j] = tmp;
                }
            }
        }
        else
        {
            for(int j = 0; j < m ;j++)
            {
                for(int i = 0; i < n / 2; i++)
                {
                    int tmp = res[i][j];
                    res[i][j] = res[n - 1 - i][j];
                    res[n - 1 - i][j] = tmp;
                }
            }
        }
        return res;
    }
    public static void printMatrix(int[][] matrix)
    {
        int m = matrix.length, n = matrix[0].length;
        for(int i = 0; i < m; i++)
        {
            for(int j = 0; j < n; j++) System.out.print(matrix[i][j] + " ");
            System.out.println("");
        }
    }
    public static void main(String[] args)
    {
        int[][] input = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}};
        int[][] output1 = rotate(input, 0);
        int[][] output2 = rotate(input, 1);
        System.out.println("input");
        printMatrix(input);
        System.out.println("output1");
        printMatrix(output1);
        System.out.println("output2");
        printMatrix(output2);
    }
}

相关文章

网友评论

      本文标题:Rotate Matrix

      本文链接:https://www.haomeiwen.com/subject/cnyrsxtx.html