2차원 배열 회전 시키기

public class round {
    private static int[][] solution(int[][] matrix, int r) {
        int count = r%4; //1=90도, 2=180도 , 3=270도 , 4=360도, 5->1, 6->2, 7->3 8->4 

        //count 만큼 회전 시키기 위한 반복문
        for (int d = 0; d < count; d++) {
            //rotate() 회전시키는 기능을 담당하는 기능
            matrix = rotate(matrix);
        }

        return matrix;
    }

    //90도 회전 기능
    public static int[][] rotate(int[][] matrix){
        int m = matrix[0].length; //col
        int n = matrix.length;    //row

        //2차원 배열 생성
        int[][] arry = new int[m][n];

        for (int i = 0; i < n; i++) {
            for (int j = 0; j < m; j++) {
                arry[j][n - 1 - i] = matrix[i][j];
            }
        }
        return arry;
    }

    //출력 기능
    static void print(int[][] arr) {
        for (int i=0; i<arr.length; i++) {
            for (int j=0; j<arr[i].length; j++) {
                System.out.print(arr[i][j] + " ");
            }
            System.out.println("");
        }
    }

    public static void main(String[] args) {
        int[][] matrix = {{1,2}, {3,4},{5,6}};
        int[][] result;
        int degree = 1; //회전 횟수 입력

        result = solution(matrix, 1);
        print(result);
    }
}

+ Recent posts