백트래킹을 걸 수 없는 탐색 ( target이 움직여서 중복방문을 막을 수 없을 시)시
사이클도는 구간을 찾아 사이클마다 각 지점에 대한 체크만 해주고 탐색은 더 진행하지 않는 방법을 사용.
중복 구간 탐색을 막고 사이클은 돌며 target이 오나 안오나 감시할 수 있다.
import sys
input = sys.stdin.readline
from collections import deque
def BFS(N,K):
odd_even_visited = [[False]*500001 for _ in range(2)]
queue = deque()
queue.append([N,K,0,0])
cur_sister = K
odd_even_visited[0][N] = True
while queue:
cur_node,cur_sister,cur_time,cur_flag = queue.popleft()
if cur_sister > 500000:
print(-1)
exit()
# 중복 체크가 불가능한 BFS(target이 움직여서 방문한곳 또 들러야함)는 순환구간을 찾아 check하면 됨.
# +1, -1 구간에 동생이 오면 걸림.
if odd_even_visited[cur_flag][cur_sister]:
print(cur_time)
exit()
new_flag = cur_flag^ 1
for next_node in (cur_node-1,cur_node+1,cur_node*2):
if 0<=next_node<=500000 and not odd_even_visited[new_flag][next_node]:
next_time = cur_time + 1
next_sister = cur_sister + next_time
odd_even_visited[new_flag][next_node] = True
queue.append([next_node,next_sister,next_time,new_flag])
N,K = map(int,input().split())
BFS(N,K)
'practivceAlgorithm > 백준' 카테고리의 다른 글
[백준][Python] 6549 히스토그램에서 가장 큰 직사각형 (0) | 2021.08.10 |
---|---|
[백준][Python] 1725 히스토그램 : stack (0) | 2021.08.10 |
[백준][Python] 16234 인구이동 (0) | 2021.08.10 |
[백준][Python] 11123 양한마리 (0) | 2021.08.10 |
[백준][Python] 1436 영화감독숌 (0) | 2021.08.10 |