PS (C, C++)
[백준/C++] 16397 탈출
최연재
2024. 12. 1. 02:59
https://www.acmicpc.net/problem/16397
코드
#include <iostream>
#include <queue>
#include <string>
using namespace std;
#define FASTIO ios::sync_with_stdio(false); cin.tie(NULL);
#define MAX 99999
int n, t, g, tmp;
bool visit[MAX];
string s;
queue<pair<int, int>> q;
void bfs() {
while (!q.empty()) {
int now = q.front().first;
int cnt = q.front().second;
q.pop();
if (cnt > t) continue;
if (now == g) {
cout << cnt;
return;
}
if (now + 1 <= MAX && !visit[now+1]) {
q.push({ now + 1, cnt+1 });
visit[now + 1] = true;
}
if (now * 2 <= MAX && now != 0) {
s = to_string(now*2);
s[0] -= 1;
tmp = stoi(s);
if (!visit[tmp]) {
q.push({ tmp , cnt+1});
visit[tmp] = true;
}
}
}
cout << "ANG";
}
int main() {
FASTIO;
cin >> n >> t >> g;
q.push({ n, 0 });
visit[n] = true;
bfs();
return 0;
}
설명
A를 누르면 N + 1이 되고 B를 누르면 N*2에서 0이 아닌 가장 높은 자릿수가 1이 줄어드는 것을 구현합니다. 큐에는 현재값과 버튼을 누른 횟수를 저장하고 BFS를 돌려줍니다.
느낀 점
버튼의 동작 방식을 그대로 구현하고, 큐에는 {현재 값, 버튼 누른 횟수}를 기록해주면서 문제를 풀면 됩니다!