BOJ 12761 - 돌다리 (Python)

조민수·2024년 2월 19일
0

BOJ

목록 보기
10/64

S1, BFS


풀이

  • 8번의 움직임이 있다고 이미 문제에서 힌트를 준다.
    • [-1, +1, -A, +A, -B, +B, x A, x B]
  • 이렇게 8번의 움직임을 bfs를 통해 해결하면 끝
# 돌다리, S1

from sys import stdin
from collections import deque

A, B, N, M = map(int,stdin.readline().split())

visited = [0] * 100001

def bfs(start):
    q = deque()
    q.append(start)
    visited[start] = 1

    move = [-1, 1, -1 * A, -1 * B, A, B, A, B]

    while q:
        now = q.popleft()

        for i in range(8):
            if i < 6:
                nx = now + move[i]
                if 0<=nx<100001 and not visited[nx]:
                    q.append(nx)
                    visited[nx] = visited[now] + 1

            elif i == 6 or i == 7:
                nx = now * move[i]
                if 0<=nx<100001 and not visited[nx]:
                    q.append(nx)
                    visited[nx] = visited[now] + 1

bfs(N)
print(visited[M] - 1)
profile
사람을 좋아하는 Front-End 개발자

0개의 댓글