[백준] 5011 Robots on a grid

0

백준

목록 보기
66/271
post-thumbnail

백준 5011 Robots on a grid

  • https://www.acmicpc.net/problem/5011

  • 오른쪽과 아래쪽으로만 이동할 수 있을 때 (0,0)에서 (n-1,n-1)좌표로 이동하는 경로의 개수
    -> DP 사용

  • 상하좌우 모든 방향으로 이동할 수 있을 때 (0,0)에서 (n-1,n-1)좌표로 이동하는 경로의 존재 여부
    -> BFS 사용

  • cache[][]를 -1로 초기화하기 위해서는 unsigned long long 자료형을 사용할 수 없음에 주의하자

#include <iostream>
#include <cstring>
#include <queue>
#include <string>
using namespace std;

typedef long long int ll;

const ll MOD = 2147483648 - 1; //2^31 - 1

int n;
//빈 칸 '.', 장애물 칸 '#'
string mp[1001];

//dp - Right & Down
ll cache[1001][1001];

ll dp(int r, int c) {
	//base case
	//(R,C)에 도착한 경우 경로 하나 발견
	if (r == n - 1 && c == n - 1) return 1;

	//범위 밖으로 간 경우 경로 X
	if (r < 0 || r > n-1) return 0;
	if (c < 0 || c > n-1) return 0;

	//장애물이 있는 칸인 경우 경로 X
	if (mp[r][c] == '#') return 0;

	ll& ret = cache[r][c];
	if (ret != -1) return ret;

	ret = (dp(r + 1, c) + dp(r, c + 1)) % MOD;
	return ret;
}


//bfs - Right & Left & Up & Down
int dirr[4] = { 1,-1,0,0 };
int dirc[4] = { 0,0,1,-1 };
bool visited[1001][1001];

bool bfs() {
	queue<pair<int, int>> q;
	q.push(make_pair(0, 0));

	while (!q.empty()) {
		pair<int, int> cur = q.front();
		int curr = cur.first;
		int curc = cur.second;
		q.pop();
	
		//(R,C)에 도착한 경우 경로 발견
		if (curr == n - 1 && curc == n - 1) 
			return true;

		if (visited[curr][curc]) continue;
		visited[curr][curc] = true;

		for (int i = 0; i < 4; i++) {
			int nextr = curr + dirr[i];
			int nextc = curc + dirc[i];

			if (nextr < 0 || nextr > n - 1) continue;
			if (nextc < 0 || nextc > n - 1) continue;
			if (mp[nextr][nextc] == '#') continue;

			q.push(make_pair(nextr, nextc));
		}
	}

	return false;
}

int main() {
	ios_base::sync_with_stdio(false);
	cin.tie(NULL);
	cout.tie(NULL);

	for (int i = 0; i < 1001; ++i)
		for (int j = 0; j < 1001; ++j) {
			cache[i][j] = -1;
			visited[i][j] = false;
		}

	cin >> n;
	for (int i = 0; i < n; ++i)
		cin >> mp[i];

	//Right & Down 경로의 개수
	ll path = dp(0, 0);
	if (path != 0) {
		cout << path;
		return 0;
	}

	//Right & Left & Up & Down 경로 존재
	if (bfs()) cout << "THE GAME IS A LIE";
	else cout << "INCONCEIVABLE";

	return 0;
}
profile
Be able to be vulnerable, in search of truth

0개의 댓글