ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [백준]14500. 테트로미노 (Java)
    알고리즘/백준 2021. 9. 3. 15:04

    💡 문제 분석

    /**
     *  1. 테트로미노 5가지, 회전 4방향, 대칭, 총 40가지
     *  2. 모든 칸을 순회하면서 40가지 테트로미노를 전부 계산해본다.
     */


    ⌨️ 코드

    JAVA

    import java.io.*;
    import java.util.*;
    
    public class Q14500 {
        private static int[][] dy = {
                {0, 0, 0}, {1, 2, 3}, {0, 1, 1}, {1, 2, 2}, {1, 2, 2},
                {1, 1, 1}, {1, 1, 1}, {1, 1, 2}, {1, 1, 2}, {0, 1, 1},
                {0, 1, 1}, {0, 0, 1}, {1, 1, 1}, {1, 2, 1}, {1, 2, 1},
                {0, 0, 1}, {0, 0, 1}, {0, 1, 2}, {0, 1, 2}
        };
        private static int[][] dx = {
                {1, 2, 3}, {0, 0, 0}, {1, 0, 1}, {0, 0, 1}, {0, 0, -1},
                {0, 1, 2}, {0, -1, -2}, {0, 1, 1}, {0, -1, -1}, {1, 1, 2},
                {-1, -1, -2}, {1, 2, 1}, {-1, 0, 1}, {0, 0, 1}, {0, 0, -1},
                {1, 2, 2}, {-1, -2, -2}, {-1, -1, -1}, {1, 1, 1}
        };
    
        public static void main(String[] args) throws Exception {
            BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
            StringTokenizer st = new StringTokenizer(br.readLine().trim(), " ");
            int N = Integer.parseInt(st.nextToken());
            int M = Integer.parseInt(st.nextToken());
            int[][] map = new int[N][M];
            for (int i = 0; i < N; i++) {
                st = new StringTokenizer(br.readLine(), " ");
                for (int j = 0; j < M; j++) {
                    map[i][j] = Integer.parseInt(st.nextToken());
                }
            }
    
            int max = Integer.MIN_VALUE;
            for (int i = 0; i < N; i++) {
                for (int j = 0; j < M; j++) {
                    for (int k = 0; k < dy.length; k++) {
                        int sum = 0;
                        sum += map[i][j];
                        for (int l = 0; l < 3; l++) {
                            int nr = i + dy[k][l];
                            int nc = j + dx[k][l];
                            if (nr >= 0 && nr < N && nc >= 0 && nc < M) {
                                sum += map[nr][nc];
                            } else {
                                sum = 0;
                                break;
                            }
                        }
                        if (max < sum)
                            max = sum;
                    }
                }
            }
            System.out.println(max);
        }
    }

    '알고리즘 > 백준' 카테고리의 다른 글

    [백준]14503. 로봇 청소기 (Java)  (0) 2021.09.03
    [백준]14502. 연구소 (Java)  (0) 2021.09.03
    [백준]13549. 숨바꼭질3 (Java)  (0) 2021.09.03
    [백준]12886. 돌 그룹 (Java)  (0) 2021.09.03
    [백준]12851. 숨바꼭질2 (Java)  (0) 2021.09.03

    댓글

Designed by Tistory.