ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [백준] 3085. 사탕 게임
    PS/Java 2022. 4. 6.

    상근이는 어렸을 적에 "봄보니 (Bomboni)" 게임을 즐겨했다.

     

    가장 처음에 N×N크기에 사탕을 채워 놓는다. 사탕의 색은 모두 같지 않을 수도 있다. 상근이는 사탕의 색이 다른 인접한 두 칸을 고른다. 그 다음 고른 칸에 들어있는 사탕을 서로 교환한다. 이제, 모두 같은 색으로 이루어져 있는 가장 긴 연속 부분(행 또는 열)을 고른 다음 그 사탕을 모두 먹는다.

    사탕이 채워진 상태가 주어졌을 때, 상근이가 먹을 수 있는 사탕의 최대 개수를 구하는 프로그램을 작성하시오.


    입력

    첫째 줄에 보드의 크기 N이 주어진다. (3 ≤ N ≤ 50)

    다음 N개 줄에는 보드에 채워져 있는 사탕의 색상이 주어진다. 빨간색은 C, 파란색은 P, 초록색은 Z, 노란색은 Y로 주어진다.

    사탕의 색이 다른 인접한 두 칸이 존재하는 입력만 주어진다.

    출력

    첫째 줄에 상근이가 먹을 수 있는 사탕의 최대 개수를 출력한다.


    예제 입력 3 

    5
    YCPZY
    CYZZP
    CCPPP
    YCYZC
    CPPZZ

    예제 출력 3

    4

    import java.io.BufferedReader;
    import java.io.InputStreamReader;
    
    public class Main {
        static int N;
        static char[][] arr;
    
        public static void main(String[] args) throws Exception{
            BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
            N = Integer.parseInt(br.readLine());
            arr = new char[N][N];
    
            for(int i = 0; i < N; i++) {
                StringBuilder sb = new StringBuilder(br.readLine());
                arr[i] = sb.toString().toCharArray();
            }
            int max = Integer.MIN_VALUE;
            for(int i = 0; i < N; i++) {
                for(int j = 0; j < N; j++) {
                    // 가로
                    char tmpChar;
                    int horizontal = 0;
                    if(i < N - 1) {
                        tmpChar = arr[i][j];
                        arr[i][j] = arr[i + 1][j];
                        arr[i + 1][j] = tmpChar;
                        horizontal = validate(arr);
                        tmpChar = arr[i + 1][j];
                        arr[i + 1][j] = arr[i][j];
                        arr[i][j] = tmpChar;
                    }
    
                    // 세로
                    int vertical = 0;
                    if(j < N - 1) {
                        tmpChar = arr[i][j];
                        arr[i][j] = arr[i][j + 1];
                        arr[i][j + 1] = tmpChar;
                        vertical = validate(arr);
                        tmpChar = arr[i][j + 1];
                        arr[i][j + 1] = arr[i][j];
                        arr[i][j] = tmpChar;
                    }
    
                    max = Math.max(max, Math.max(horizontal, vertical));
                }
            }
    
            System.out.println(max);
        }
    
        public static int validate(char[][] tmp) {
            // 행 검사
            int horCount = Integer.MIN_VALUE;
            for(int i = 0; i < N; i++) {
                char c = tmp[i][0];
                int cnt = 1;
                for(int j = 1; j < N; j++) {
                    if(c == tmp[i][j]) {
                        cnt++;
                    } else {
                        c = tmp[i][j];
                        horCount = Math.max(cnt, horCount);
                        cnt = 1;
                    }
                    horCount = Math.max(cnt, horCount);
                }
            }
    
            // 열 검사
            int verCount = Integer.MIN_VALUE;
            for(int i = 0; i < N; i++) {
                char c = tmp[0][i];
                int cnt = 1;
                for(int j = 1; j < N; j++) {
                    if(c == tmp[j][i]) {
                        cnt++;
                    } else {
                        c = tmp[j][i];
                        verCount = Math.max(cnt, verCount);
                        cnt = 1;
                    }
                    verCount = Math.max(cnt, verCount);
                }
            }
    
            return Math.max(horCount, verCount);
        }
    }

     

    'PS > Java' 카테고리의 다른 글

    [백준] 9237. 이장님 초대  (0) 2022.04.06
    [백준] 6603. 로또  (0) 2022.04.06
    [백준] 1932. 정수 삼각형  (0) 2022.04.06
    [백준] 1759. 암호 만들기  (0) 2022.04.06
    [백준] 5568. 카드 놓기  (0) 2022.04.06

    댓글

Designed by Tistory.