Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- geometry
- string
- Number Theory
- 자바
- Matrix
- Method
- array
- java
- SQL
- dynamic programming
- Counting
- simulation
- hash table
- Data Structure
- 코테
- Stack
- Math
- greedy
- Tree
- 파이썬
- implement
- 구현
- Binary Search
- Binary Tree
- two pointers
- Class
- database
- bit manipulation
- 코딩테스트
- sorting
Archives
- Today
- Total
코린이의 소소한 공부노트
[백준 온라인 저지] 1018. 체스판 다시 칠하기 본문
지민이는 자신의 저택에서 MN개의 단위 정사각형으로 나누어져 있는 M×N 크기의 보드를 찾았다. 어떤 정사각형은 검은색으로 칠해져 있고, 나머지는 흰색으로 칠해져 있다. 지민이는 이 보드를 잘라서 8×8 크기의 체스판으로 만들려고 한다.
체스판은 검은색과 흰색이 번갈아서 칠해져 있어야 한다. 구체적으로, 각 칸이 검은색과 흰색 중 하나로 색칠되어 있고, 변을 공유하는 두 개의 사각형은 다른 색으로 칠해져 있어야 한다. 따라서 이 정의를 따르면 체스판을 색칠하는 경우는 두 가지뿐이다. 하나는 맨 왼쪽 위 칸이 흰색인 경우, 하나는 검은색인 경우이다.
보드가 체스판처럼 칠해져 있다는 보장이 없어서, 지민이는 8×8 크기의 체스판으로 잘라낸 후에 몇 개의 정사각형을 다시 칠해야겠다고 생각했다. 당연히 8*8 크기는 아무데서나 골라도 된다. 지민이가 다시 칠해야 하는 정사각형의 최소 개수를 구하는 프로그램을 작성하시오.
1. 입력
- 첫째 줄에 N과 M이 주어진다. N과 M은 8보다 크거나 같고, 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
'코딩테스트 풀이 > JAVA' 카테고리의 다른 글
[백준 온라인 저지] 2108. 통계학 (0) | 2023.06.22 |
---|---|
[백준 온라인 저지] 17103. 골드바흐 파티션 (0) | 2023.06.22 |
[LeetCode/Easy] 2231. Largest Number After Digit Swaps by Parity (0) | 2023.06.21 |
[LeetCode/Easy] 2164. Sort Even and Odd Indices Independently (0) | 2023.06.21 |
[LeetCode/Easy] 2144. Minimum Cost of Buying Candies With Discount (0) | 2023.06.21 |