[문제 링크]
https://www.acmicpc.net/problem/14502
[난이도]
- Gold 4
[알고리즘]
- BFS
- 백트래킹
[코드]
import java.io.*;
import java.util.*;
public class Main {
static int N, M, result = 0;
static int[][] map;
static int[] dx = {-1, 1, 0, 0};
static int[] dy = {0, 0, -1, 1};
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
N = Integer.parseInt(st.nextToken());
M = Integer.parseInt(st.nextToken());
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());
}
}
backTracking(0);
System.out.println(result);
}
static void backTracking(int depth) {
if (depth == 3) {
result = Math.max(result, checkSafeArea(bfs()));
return;
}
for (int i = 0; i < N; i++) {
for (int j = 0; j < M; j++) {
if (map[i][j] == 0) {
map[i][j] = 1; // 벽을세움
backTracking(depth + 1);
map[i][j] = 0; // 벽을 되돌려놓음
}
}
}
}
static int[][] bfs() {
int[][] newMap = new int[N][M];
for (int i = 0; i < N; i++) {
System.arraycopy(map[i], 0, newMap[i], 0, M);
}
Queue<int[]> queue = new LinkedList<>();
for (int i = 0; i < N; i++) {
for (int j = 0; j < M; j++) {
if (newMap[i][j] == 2) {
queue.add(new int[]{i, j});
}
}
}
while (!queue.isEmpty()) {
int[] tmp = queue.poll();
int x = tmp[0];
int y = tmp[1];
for (int i = 0; i < 4; i++) {
int nx = x + dx[i];
int ny = y + dy[i];
if (nx >= 0 && nx < N && ny >= 0 && ny < M) {
if (newMap[nx][ny] == 0) {
newMap[nx][ny] = 2;
queue.add(new int[]{nx, ny});
}
}
}
}
return newMap;
}
static int checkSafeArea(int[][] newMap) {
int safeArea = 0;
for (int i = 0; i < N; i++) {
for (int j = 0; j < M; j++) {
if (newMap[i][j] == 0) {
safeArea++;
}
}
}
return safeArea;
}
}
[풀이]
4방탐색을하며 바이러스를 퍼트리는 부분은 일반적인 bfs알고리즘을 활용해 푼다. 더 생각해야할 부분은 벽을 3개 세우는데 반드시 3개를 세워야하기 때문에 백트래킹을 활용해 벽 3개를 세울 수 있는 가능한 모든 경우의 수를 생각해 세운 후 바이러스를 퍼트리고 다 퍼진후 안전한 공간의 개수를 세준다.
'코딩테스트' 카테고리의 다른 글
백준 1931: 회의실배정 [JAVA] (0) | 2024.07.19 |
---|---|
백준 1446 : 지름길 [JAVA] (0) | 2024.07.05 |
백준 2156 : 포도주 시식 [JAVA] (0) | 2024.06.27 |
백준 2529 : 부등호 [JAVA] (0) | 2024.06.21 |
백준 2023 : 신기한 소수 [JAVA] (0) | 2024.06.20 |