Algorithm

(BOJ) 1697 풀이

snwo 2022. 2. 7. 18:07

1697

#include<bits/stdc++.h>
using namespace std;
int visited[100002];
int main(void){
    ios::sync_with_stdio(0);cin.tie(0);
    queue<int> Q;
    fill(visited,visited+100002,-1);
    int N,K;
    cin >> N >> K;
    Q.push(N);
    visited[N]=0;
    while(visited[K]==-1){
        int cur=Q.front();
        Q.pop();
        for(int nxt:{cur-1,cur+1, cur*2}){
            if(nxt<0 || nxt >100000 || visited[nxt]!=-1)continue;
            Q.push(nxt);
            visited[nxt]=visited[cur]+1;
        }
    }
    cout << visited[K] << '\n';
}

동생은 가만히 있으므로, X+1, X-1, X*2 이 3개를 큐에 넣으면서 visited 에 초를 1씩 증가시키다가 목적지에 최초로 도달하면 그 때 값을 출력해준다.

먼저 pair 으로 좌표랑 초를 같이 넣을려 했는데, 메모리초과가 나서 배열로 바꿧당

visited[nxt]≠-1 을 안넣어줘서 메모리초과가 난 걸 수도 있다.