Rotate Matrix

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);
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容