[알고리즘/백준] 1697번 : 숨바꼭질(python)

유현민·2022년 3월 10일
0

알고리즘

목록 보기
45/253

간단하게 풀린다. 3가지 경우를 계속 계산

from collections import deque

N, K = map(int, input().split())
q = deque()
q.append(N)
MAX = 10 ** 5
visit = [0] * (MAX + 1)
while q:
    x = q.popleft()
    if x == K:
        print(visit[x])
        break
    for nx in (x-1, x+1, x*2):
        if 0 <= nx <= MAX and not visit[nx]:
            visit[nx] = visit[x] + 1
            q.append(nx)
profile
smilegate

0개의 댓글