반응형
[백준 Baekjoon] 7569번 토마토- JAVA
문제 풀이
상자에 들어 있는 토마토가 모두 익을 때까지 최소 날짜를 출력하는 문제이다. 최소 날짜와 위, 아래, 왼쪽, 오른쪽, 앞, 뒤 여섯 방향을 보고 bfs탐색으로 푸는 문제란 걸 알았다.
3차원 도형으로 복잡해 보이지만, 3차원 배열로 입력받고 토마토가 있는 위치에서 여섯 방향으로 bfs탐색을 하면 쉽게 풀리는 문제이다. 7576번 토마토 문제에서 살짝 업그레이드 된 문제이다.
https://dlee0129.tistory.com/202
입력으로 주어진 토마토는 1 익은 토마토, 0 익지 않은 토마토, -1 토마토가 들어있지 않은 칸 이렇게 세 가지 종류이다.
bfs탐색으로 탐색해야 하는 칸(cnt)은 M * N (상자의 크기) - 익은 토마토 - 토마토가 들어있지 않은 칸이다.
익은 토마토에서 주변 토마토가 익기 때문에 큐에 모든 익은 토마토를 저장하고 bfs탐색을 한다. bfs 탐색으로 새로 탐색하는 칸은 방문하지 않았으며 토마토가 들어있지 않은 칸으로 새로 토마토가 익는 경우이다. 이 경우 cnt를 감소해주고 큐에 추가, visit배열에서 방문 체크해준다.
한번 큐에 들어있는 모든 토마토에 대해서 bfs탐색이 완료되면 날짜(answer)가 증가한다.
cnt가 0이 되면 모든 토마토가 익었으므로 날짜를 출력하고 종료한다.
소스 코드
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.LinkedList;
import java.util.Queue;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
int M = Integer.parseInt(st.nextToken());
int N = Integer.parseInt(st.nextToken());
int H = Integer.parseInt(st.nextToken());
int[][][] map = new int[H][N][M];
Queue<Node> queue = new LinkedList<>();
boolean[][][] visit = new boolean[H][N][M];
int cnt = H * N * M;
for (int i = 0; i < H; i++) {
for (int j = 0; j < N; j++) {
st = new StringTokenizer(br.readLine());
for (int k = 0; k < M; k++) {
map[i][j][k] = Integer.parseInt(st.nextToken());
if (map[i][j][k] == 1) {
queue.add(new Node(i, j, k));
visit[i][j][k] = true;
cnt--;
} else if (map[i][j][k] == -1) {
cnt--;
}
}
}
}
int[] dx = {1, -1, 0, 0, 0, 0};
int[] dy = {0, 0, 1, 0, -1, 0};
int[] dz = {0, 0, 0, 1, 0, -1};
int answer = 0;
while (!queue.isEmpty()) {
if (cnt == 0) {
System.out.println(answer);
return;
}
int size = queue.size();
for (int i = 0; i < size; i++) {
Node cur = queue.poll();
for (int k = 0; k < 6; k++) {
int nx = cur.x + dx[k];
int ny = cur.y + dy[k];
int nz = cur.z + dz[k];
if (nx < 0 || ny < 0 || nz < 0 || nx >= H || ny >= N || nz >= M) continue;
if (visit[nx][ny][nz] || map[nx][ny][nz] == -1) continue;
queue.add(new Node(nx, ny, nz));
visit[nx][ny][nz] = true;
cnt--;
}
}
answer++;
}
System.out.println(-1);
}
public static class Node {
int x;
int y;
int z;
public Node(int x, int y, int z) {
this.x = x;
this.y = y;
this.z = z;
}
}
}
반응형
'알고리즘(Algorithm) > 백준(Baekjoon)' 카테고리의 다른 글
[백준 Baekjoon] 2641번 다각형그리기 - JAVA (0) | 2021.12.14 |
---|---|
[백준 Baekjoon] 2659번 십자카드 문제 - JAVA (0) | 2021.12.13 |
[백준 Baekjoon] 7576번 토마토- JAVA (0) | 2021.12.06 |
[백준 Baekjoon] 15711번 환상의 짝궁- JAVA (0) | 2021.12.05 |
[백준 Baekjoon] 18870번 좌표 압축 - JAVA (0) | 2021.12.03 |