백준/BFS
백준 1697번 숨바꼭질 (c++)
Daekyue
2023. 11. 6. 17:12
[Silver I] 숨바꼭질 - 1697
분류
너비 우선 탐색, 그래프 이론, 그래프 탐색
문제 설명
수빈이는 동생과 숨바꼭질을 하고 있다. 수빈이는 현재 점 N(0 ≤ N ≤ 100,000)에 있고, 동생은 점 K(0 ≤ K ≤ 100,000)에 있다. 수빈이는 걷거나 순간이동을 할 수 있다. 만약, 수빈이의 위치가 X일 때 걷는다면 1초 후에 X-1 또는 X+1로 이동하게 된다. 순간이동을 하는 경우에는 1초 후에 2*X의 위치로 이동하게 된다.
수빈이와 동생의 위치가 주어졌을 때, 수빈이가 동생을 찾을 수 있는 가장 빠른 시간이 몇 초 후인지 구하는 프로그램을 작성하시오.
입력
첫 번째 줄에 수빈이가 있는 위치 N과 동생이 있는 위치 K가 주어진다. N과 K는 정수이다.
출력
수빈이가 동생을 찾는 가장 빠른 시간을 출력한다.
#include <bits/stdc++.h>
using namespace std;
int main(void) {
ios::sync_with_stdio(0);
cin.tie(0);
int dx[3] = { 1, -1, 2 };
int vis[200001], n, k;
int future;
cin >> n >> k;
queue <int> Q;
Q.push(n);
vis[n] = 1;
for (int i = 0; i < 200001; i++)
vis[i] = 0;
while (!Q.empty())
{
int cur = Q.front();
if (cur == k)
{
cout << vis[cur];
return 0;
}
Q.pop();
for (int i = 0; i < 3; i++) {
if (i == 2)
future = dx[i] * cur;
else
future = cur + dx[i];
if (future < 0 || future >= 200000) continue;
if (vis[future]) continue;
Q.push(future);
vis[future] = vis[cur] + 1;
}
}
}
이 문제는 일반적으로 2차원에서 했던 BFS를 1차원에서 진행하는 방식으로 문제를 풀었다.
문제를 풀면서 어려웠던 점은 처음 풀 때는 future가 100000이 넘어가면 continue를 진행하게 풀었는데
100000이 넘어간 수에서 아래로 내려오는 방법도 있기에 vis의 크기를 200000으로 늘려서 진행하였다