문제
지도가 주어지면 모든 지점에 대해서 목표지점까지의 거리를 구하여라.
문제를 쉽게 만들기 위해 오직 가로와 세로로만 움직일 수 있다고 하자.
입력
지도의 크기 n과 m이 주어진다. n은 세로의 크기, m은 가로의 크기다.(2 ≤ n ≤ 1000, 2 ≤ m ≤ 1000)
다음 n개의 줄에 m개의 숫자가 주어진다. 0은 갈 수 없는 땅이고 1은 갈 수 있는 땅, 2는 목표지점이다. 입력에서 2는 단 한개이다.
출력
각 지점에서 목표지점까지의 거리를 출력한다. 원래 갈 수 없는 땅인 위치는 0을 출력하고, 원래 갈 수 있는 땅인 부분 중에서 도달할 수 없는 위치는 -1을 출력한다.
코드
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 {
static int N; //세로
static int M; //가로
static int[][] map;
static int[][] result;
static int[] dx = {0, 0, 1, -1};
static int[] dy = {1, -1, 0, 0};
static int startX;
static int startY;
static Queue<int[]> queue = new LinkedList<>();
static boolean[][] visited;
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];
result = new int[N][M];
visited = new boolean[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());
if (map[i][j] == 2) {
startX = i;
startY = j;
result[i][j] = 0;
} else if (map[i][j] == 0) { //갈 수 없는 길
visited[i][j] = true;
result[i][j] = 0;
}
}
}
bfs(startX, startY);
for (int i = 0; i < N; i++) {
for (int j = 0; j < M; j++) {
if (!visited[i][j]) {
System.out.print(-1 + " ");
} else {
System.out.print(result[i][j] + " ");
}
}
System.out.println();
}
}
static void bfs(int startX, int startY) {
queue.offer(new int[]{startX, startY});
visited[startX][startY] = true;
while (!queue.isEmpty()) {
int[] current = queue.poll();
int x = current[0];
int y = current[1];
for (int i = 0; i < 4; i++) {
for (int j = 0; j < 4; j++) {
int nx = x + dx[i];
int ny = y + dy[i];
if (nx >= 0 && ny >= 0 && nx < N && ny < M) {
if (!visited[nx][ny] && map[nx][ny] == 1) { //방문하지 않았고 갈 수 있는 길일 때
result[nx][ny] = result[x][y] + 1;
visited[nx][ny] = true;
queue.offer(new int[]{nx, ny});
}
}
}
}
}
}
}
bfs에서 첫 시작점을 queue에 넣고 시작하면 금방 풀리는 문제였다.
문제 출처
'Study > Test(Java)' 카테고리의 다른 글
| [백준] 9095 1, 2, 3 더하기 Java (0) | 2024.04.24 |
|---|---|
| [백준] 11724 연결 요소의 개수 Java (0) | 2024.04.24 |
| [백준] 7576 토마토 Java (0) | 2024.04.24 |
| [백준] 2630 색종이 만들기 Java (0) | 2024.04.21 |
| [백준] 1931 회의실 배정 Java (0) | 2024.04.20 |