Algorithm

(BOJ) 5014 풀이

snwo 2022. 2. 9. 18:58

5014

#include <bits/stdc++.h>
#define MAX 1000001
using namespace std;
int visited[MAX + 1];
int main(void)
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    int F, S, G, U, D, flag = 0;
    cin >> F >> S >> G >> U >> D;
    queue<int> Q;
    fill(visited, visited + F+1, -1);
    Q.push(S);
    visited[S] = 0;
    while (!Q.empty()&&flag==0)
    {
        int v = Q.front();
        Q.pop();
        for (auto m : {U,-D})
        {
            if(v==G){
                cout << visited[v] << '\n';
                flag=1;
                break;
            }
            if (v+m > F || v+m <=0 || visited[v+m] != -1)
                continue;
            visited[v+m] = visited[v] + 1;
            Q.push(v+m);
        }
    }
    if (!flag)
    {
        cout << "use the stairs" << '\n';
    }
}

U 만큼 올라가는 경우, D 만큼 내려가는 경우 두 가지 경우에 대해 BFS 를 돌린다.

큐가 빌 떄까지 도착지 G 에 도착하지 못하는 경우에는 use the stairs 를 출력해준다.