Notice
Recent Posts
Recent Comments
Link
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
Archives
Today
Total
관리 메뉴

0과 1 사이

[파이썬(python)] 백준 16928 뱀과 사다리 게임 본문

코딩테스트

[파이썬(python)] 백준 16928 뱀과 사다리 게임

고후 2022. 2. 21. 11:43

굉장히 뻘짓을 했다.. 

이 문제는 dfs나 bfs 로 풀어야하는것 같다. ㅜ

아. dfs로 풀면 최단거리가 나오지 않는다.

최단거리 문제는 bfs로 풀어야한다.

 

정답 코드..

 

from collections import deque

n, m = map(int, input().split())
gamemap = [i for i in range(101)] #게임판. i번째 칸에는 i로 이동
distance = [0] * 101 # 1번부터 해당칸까지의 거리

for i in range(n+m):
    x, y = map(int, input().split())
    gamemap[x] = y #게임판. 사다리가 있으면 x번째 칸에서 y로 이동
    
p = 1
queue = deque([p])

while p != 100:
    #1~6 까지 중에 선택.
    #100에 도착할 때까지
    p = queue.popleft()

    for j in range(1, 7):
        if p+j <= 100:
            if distance[gamemap[p+j]] == 0:
                queue.append(gamemap[p+j])
                distance[gamemap[p+j]] = distance[p] + 1

print(distance[100])
Comments