코린이의 소소한 공부노트

[백준 온라인 저지] 1018. 체스판 다시 칠하기 본문

코딩테스트 풀이/JAVA

[백준 온라인 저지] 1018. 체스판 다시 칠하기

무지맘 2023. 6. 22. 11:36

지민이는 자신의 저택에서 MN개의 단위 정사각형으로 나누어져 있는 M×N 크기의 보드를 찾았다. 어떤 정사각형은 검은색으로 칠해져 있고, 나머지는 흰색으로 칠해져 있다. 지민이는 이 보드를 잘라서 8×8 크기의 체스판으로 만들려고 한다.

체스판은 검은색과 흰색이 번갈아서 칠해져 있어야 한다. 구체적으로, 각 칸이 검은색과 흰색 중 하나로 색칠되어 있고, 변을 공유하는 두 개의 사각형은 다른 색으로 칠해져 있어야 한다. 따라서 이 정의를 따르면 체스판을 색칠하는 경우는 두 가지뿐이다. 하나는 맨 왼쪽 위 칸이 흰색인 경우, 하나는 검은색인 경우이다.

보드가 체스판처럼 칠해져 있다는 보장이 없어서, 지민이는 8×8 크기의 체스판으로 잘라낸 후에 몇 개의 정사각형을 다시 칠해야겠다고 생각했다. 당연히 8*8 크기는 아무데서나 골라도 된다. 지민이가 다시 칠해야 하는 정사각형의 최소 개수를 구하는 프로그램을 작성하시오.

 

1. 입력

- 첫째 줄에 NM이 주어진다. NM8보다 크거나 같고, 50보다 작거나 같은 자연수이다.

- 둘째 줄부터 N개의 줄에는 보드의 각 행의 상태가 주어진다. B는 검은색이며, W는 흰색이다.

 

2. 출력

- 첫째 줄에 지민이가 다시 칠해야 하는 정사각형 개수의 최솟값을 출력한다.

 

3. 예제

 

4. 코드

import java.util.*;
import java.io.*;
class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
        StringTokenizer token = new StringTokenizer(br.readLine());
        int n = Integer.valueOf(token.nextToken()); // 행의 수
        int m = Integer.valueOf(token.nextToken()); // 열의 수
        int t = n;
        char[][] board = new char[n][m];
        while(t-->0) {
        	board[n-1-t] = br.readLine().toCharArray();
        }
        int min = m*n;
        for(int i=0 ; i<=n-8 ; i++) { //8*8 시작행
        	for(int j=0 ; j<=m-8 ; j++) { // 8*8 시작열
        		int startW = 0, startB =  0;
        		for(int a=0 ; a<8 ; a++) {
        			for(int b=0 ; b<8 ; b++) {
        				if(a%2==0) { // 홀수번째 행
        					if(b%2==0) { // 홀수번째 열
        						if(board[i+a][j+b]=='W') startB++;
        						else startW++;
        					} else { // 짝수번째 열
        						if(board[i+a][j+b]=='B') startB++;
        						else startW++;
        					}
        				} else { // 짝수번째 행
        					if(b%2==0) { // 홀수번째 열
        						if(board[i+a][j+b]=='B') startB++;
        						else startW++;
        					} else { // 짝수번째 열
        						if(board[i+a][j+b]=='W') startB++;
        						else startW++;
        					}
        				}
        			}
        		}
        		min = Math.min(min, Math.min(startW, startB));
        	}
        }
        bw.write(String.valueOf(min));
        bw.flush(); bw.close();
    }
}

- 14464KB, 132ms