[PS] 백준 2178 - 미로 탐색

DevHwan·2022년 1월 25일
0

BOJ

목록 보기
3/19
post-thumbnail
post-custom-banner

📌 알고리즘 분류


해당 문제는 BFS에 대한 이해가 필요한 문제입니다.
BFS

📖 문제


백준 2178

BFS(너비우선탐색)을 통해 최단거리를 구하고 해결합니다.

💻 코드


#include<iostream>
#include<vector>
#include<queue>
using namespace std;
int graph[101][101];
bool visit[101][101];
int n, m;
queue<pair<int, int>> q;
int dx[4] = { -1 , 1, 0, 0 };
int dy[4] = { 0, 0 , -1, 1 };

void BFS(int u, int v)
{
	pair<int, int> point;
	q.push({ u,v });
	visit[u][v] = true;
	while (!q.empty())
	{
		point = q.front();
		q.pop();

		for (int i = 0; i < 4; i++)
		{
			int next_x = point.first + dx[i];
			int next_y = point.second + dy[i];

			if (0 <= next_x && next_x <= n && 0 <= next_y && next_y <= m)
			{
				if (visit[next_x][next_y] == false && graph[next_x][next_y] != 0)
				{
					q.push({ next_x,next_y });
					visit[next_x][next_y] = true;
					graph[next_x][next_y] += graph[point.first][point.second];
				}
			}
		}
	}
}

int main()
{
	char c;
	cin >> n >> m;
	for (int i = 0; i < n; i++)
	{
		for (int j = 0; j < m; j++)
		{
			cin >> c;
			graph[i][j] = c - '0';
		}
	}

	for (int i = 0; i < n; i++)
	{
		for (int j = 0; j < m; j++)
		{
			visit[i][j] = false;
		}
	}

	BFS(0, 0);
	cout << graph[n - 1][m - 1];
}

profile
달리기 시작한 치타
post-custom-banner

0개의 댓글