알고리즘
[백준] 13913번: 숨바꼭질 4 - python
육빔
2024. 5. 6. 20:40
728x90
반응형
https://www.acmicpc.net/problem/13913
시험과 플젝 끝난 후 간만에 알고리즘 풀이
BFS이므로 ch 리스트를 체크하는 용도 말고 dis를 넣어서 체크해도 문제가 되지 않는다.
그 후 여기선 최단으로 바뀌는 경로의 값을 전부 다 넣어서 출력해줘야되기에 dis안에 전에 now를 넣어서 저장시켜준다.
그 후 만약 n == k 가 되면 dis를 돌아서 answer안에 투입 후 출력해준다.
from collections import deque
n, k = map(int, input().split())
ch = [0] * (100001)
dis = [0] * (100001)
ch[n] = 0
dis[n] = 0
dq = deque([n])
while dq:
now = dq.popleft()
if now == k:
print(ch[now])
answer = []
while now!=n:
answer.append(now)
now = dis[now]
answer.append(now)
answer.reverse()
print(*answer)
exit()
for next in(now-1, now+1, now*2):
if 0<=next<100001:
if ch[next] == 0:
ch[next] = ch[now] + 1
dis[next] = now
dq.append(next)
완성
728x90
반응형