View

 

알고리즘 분류: 그래프 이론, 그래프 탐색, 너비 우선 탐색

문제 링크: https://www.acmicpc.net/problem/14940

 

14940번: 쉬운 최단거리

지도의 크기 n과 m이 주어진다. n은 세로의 크기, m은 가로의 크기다.(2 ≤ n ≤ 1000, 2 ≤ m ≤ 1000) 다음 n개의 줄에 m개의 숫자가 주어진다. 0은 갈 수 없는 땅이고 1은 갈 수 있는 땅, 2는 목표지점이

www.acmicpc.net

 

 

【 풀이 】

 

모든 정점들을 방문하면서, 각 정점마다 목표 지점까지의 거리를 다른 배열에 기록해 주면 되는 문제이다.

BFS를 이용하여 쉽게 해결할 수 있다.

 

단, 목표 지점을 기준으로 BFS 를 시작해야 원하는 답을 얻을 수 있다.

왜냐하면 목표 지점에서부터 거리가 0으로 시작하기 때문이다.

 

또한 갈 수 있는 곳(1) 인데, 거리가 0으로 나오는 곳은 빠짐없이 예외처리(-1)를 하도록 하자.

 

 

 

 

【 코드 】

 

#include<iostream>
#include<queue>
#define MAX 1001
using namespace std;

int front_y[4] = { -1,1,0,0 };
int front_x[4] = { 0,0,-1,1 };

int N, M, i, j;
char miro[MAX][MAX];
int dist[MAX][MAX];
int discovered[MAX][MAX];

queue<pair<int, int>>q;

void Init(int N, int M) {
	for (int y = 1; y <= N; y++)
		for (int x = 1; x <= M; x++)
			cin >> miro[y][x];
}

void Bfs(int pos_y, int pos_x) {
	discovered[pos_y][pos_x] = true;
	q.push(make_pair(pos_y, pos_x));
	dist[pos_y][pos_x] = 0;

	while (q.empty() == false) {
		int pos_y = q.front().first;
		int pos_x = q.front().second;
		q.pop();
        
		for (int dir = 0; dir < 4; dir++) {
			int nextPos_y = pos_y + front_y[dir];
			int nextPos_x = pos_x + front_x[dir];

			if (nextPos_y < 1 || nextPos_x < 1)
				continue;
			if (nextPos_y > N || nextPos_x > M)
				continue;
			if (miro[nextPos_y][nextPos_x] == 48)
				continue;
			if (discovered[nextPos_y][nextPos_x])
				continue;

			discovered[nextPos_y][nextPos_x] = true;
			q.push(make_pair(nextPos_y, nextPos_x));
            
            		// 거리 기록 (전 정점의 거리 +1)
			dist[nextPos_y][nextPos_x] = dist[pos_y][pos_x] + 1;
		}
	}
}

int main() {
	cin >> N >> M;
	Init(N, M);
	for (i = 1; i <= N; i++) {
		for (j = 1; j <= M; j++){
			if (miro[i][j] == '2')
				break;
		}			
		if (miro[i][j] == '2')
			break;
	}

	Bfs(i, j);

	for (int y = 1; y <= N; y++) {
		for (int x = 1; x <= M; x++)
			if (miro[y][x] == '1' && dist[y][x] == 0)
				cout << -1 << " ";
			else
				cout << dist[y][x] << " ";
		cout << endl;
	}

	return 0;
}

 

728x90
Share Link
reply
«   2025/01   »
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 31