[백준] 10026 문제 - 적록색약(Java) 문제 해결 방법과 풀이코드
- 기타/알고리즘
- 2024. 3. 14.
이 문제는 골드5 문제로 일반 사람과 적록 색약 따로 BFS를 돌려서 풀어야 한다. 맨 처음 문제를 해결할 때는 BFS 돌릴 때 분기를 줘서 해결해보려고 했지만 너무 조건문이 복잡해져서 적록 색약 map을 따로 만들고 G를 R로 변경하는 방식으로 바꿨다.
가독성을 위해 조건문은 최대한 2차 까지만 하려고 노력했다. 최대한 깔끔하게 코드를 작성하는 것이 관건인 문제인 것 같다
[풀이 코드]
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.LinkedList;
import java.util.Queue;
import java.util.StringTokenizer;
//https://www.acmicpc.net/problem/10026
public class 적록색약_10026 {
/**
* 아이디어
* 1. for문을 돌아서 isVisited가 false면 bfs실행
* 2. 일반 사람 map과 색약 map을 따로 만들어서 각각 bfs를 돌린다.
* 3. 각 BFS가 실행되는 값이 정답
*/
static int N;
static char[][] normalMap;
static char[][] blindMap;
static boolean[][] isNormalVisited;
static boolean[][] isBlindVisited;
static int normalAnswer;
static int blindAnswer;
static int dx[] = {0, -1, 0, 1};
static int dy[] = {-1, 0, 1, 0};
private static void input() throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
N = Integer.parseInt(st.nextToken());
normalMap = new char[N][N];
blindMap = new char[N][N];
isNormalVisited = new boolean[N][N];
isBlindVisited = new boolean[N][N];
for (int i = 0; i < N; i++) {
st = new StringTokenizer(br.readLine());
String rgb = st.nextToken();
for (int j = 0; j < N; j++) {
normalMap[i][j] = rgb.charAt(j);
}
}
for (int i = 0; i < N; i++) {
for (int j = 0; j < N; j++) {
blindMap[i][j] = (normalMap[i][j] == 'G') ? 'R' : normalMap[i][j];
}
}
}
public static void main(String[] args) throws Exception {
input();
solve();
print();
}
private static void print() {
System.out.println(normalAnswer + " " + blindAnswer);
}
private static void solve() {
//일반 사람
for (int i = 0; i < N; i++) {
for (int j = 0; j < N; j++) {
if (!isNormalVisited[i][j]) {
bfs(i, j, normalMap[i][j], false);
normalAnswer++;
}
}
}
for (int i = 0; i < N; i++) {
for (int j = 0; j < N; j++) {
if (!isBlindVisited[i][j]) {
bfs(i, j, blindMap[i][j], true);
blindAnswer++;
}
}
}
}
//isColorBlindness는 색약 인지 아닌지 구별
private static void bfs(int y, int x, char color, boolean isColorBlindness) {
Queue<int[]> queue = new LinkedList<>();
queue.add(new int[] {y, x});
while (!queue.isEmpty()) {
int[] curYX = queue.poll();
for (int i = 0; i < dx.length; i++) {
int qy = curYX[0] + dy[i];
int qx = curYX[1] + dx[i];
if (checkBFS(qy, qx, color, isColorBlindness)) {
if (!isColorBlindness) {
isNormalVisited[qy][qx] = true;
} else {
isBlindVisited[qy][qx] = true;
}
queue.add(new int[] {qy, qx});
}
}
}
}
private static boolean checkBFS(int qy, int qx, char color, boolean isColorBlindness) {
if (qy < 0 || qy >= N || qx < 0 || qx >= N) {
return false;
}
if (!isColorBlindness) {
if (!isNormalVisited[qy][qx] && normalMap[qy][qx] == color) {
return true;
}
} else {
if (!isBlindVisited[qy][qx] && blindMap[qy][qx] == color) {
return true;
}
}
return false;
}
}
'기타 > 알고리즘' 카테고리의 다른 글
[백준] 1966 문제 - 프린터큐(Java) 문제 해결 방법과 풀이코드 (0) | 2024.05.11 |
---|---|
[백준] 2468 문제 - 안전영역(Java) 문제 해결 방법과 풀이코드 (0) | 2024.03.21 |
[백준] 7569 문제 - 토마토(Java) 문제 해결 방법과 풀이코드 (0) | 2024.03.13 |
[백준] 2178 문제 - 미로탐색(Java) BufferedReader 사용 풀이 방법 (0) | 2024.01.29 |
[알고리즘] BFS 풀이 순서와 백준 그림 문제 Java 풀이 (0) | 2024.01.10 |