import sys
from collections import deque
# 0 - 빈칸, 1 - 벽
# 이동은 상하좌우 중 인접한 칸만 가능
# 한번 지났던 지점은 다시 방문 X
# 방문해야 하는 지점의 첫 지점이 출발점, 마지막 지점이 도착점
# 순서대로 방문해야 하는 칸을 이동하는 시나리오 수
input = sys.stdin.readline
n, m = map(int,input().split())
area = [list(map(int,input().split())) for _ in range(n)]
visited = [[False]*n for _ in range(n)]
visit_list = [] # 방문해야 하는 지점들을 저장하는 배열
answer = 0
dx, dy = [-1,1,0,0], [0,0,-1,1]
for _ in range(m):
vx, vy = map(int,input().split())
visit_list.append((vx-1,vy-1))
queue = deque(visit_list) # 앞으로 방문해야 하는 지점들을 저장하는 배열
def dfs(x,y):
global answer
is_poped = False # 현재 위치가 방문해야 하는 지점인지 저장하는 Boolean값
if queue and queue[0] == (x,y): # 현재 위치가 방문해야 하는 위치라면
is_poped = True
poped_x_and_y = queue.popleft() # 앞으로 방문해야 하는 지점 Update (방문한 지점은 제거, 순서대로 이루어져야 하므로 큐 사용)
if x == visit_list[-1][0] and y == visit_list[-1][1]: # 도착 지점일 경우
if len(queue) == 0: # 이전에 방문해야 할 지점들을 모두 방문했다면 카운트 + 1
answer += 1
return True # 더 이상 탐색하지 않기 위해 Return
visited[x][y] = True # 방문처리
for i in range(4):
nx, ny = x + dx[i], y + dy[i]
if 0 <= nx < n and 0 <= ny < n and not visited[nx][ny] and area[nx][ny] == 0:
dfs(nx,ny)
visited[x][y] = False # 원상복구를 위한 방문처리 취소
if is_poped: # 원상복구를 위한 큐 데이터 삽입
queue.appendleft(poped_x_and_y)
dfs(visit_list[0][0], visit_list[0][1]) # 출발지점부터 DFS 탐색 시작
print(answer)
이번 문제는 출발지점부터 도착지점까지 가는 경로 중 방문해야 하는 m개의 지점들을 순서대로 방문한 경로를 구하는 문제이다.
먼저 출발지점부터 마지막 도착지점까지의 경로를 탐색하고, 이전까지 지나온 지점에 대한 정보를 저장해야하기 때문에 DFS 알고리즘을 선택하였다.
여기서 가장 중요한 핵심은 '방문해야 하는 지점을 순서대로 모두 방문했는지 여부'를 확인하는 것인데, 본인은 다음과 같은 방법으로 풀이하였다.
- 방문해야 하는 지점들을 저장하는 Queue 선언
- 현재 시점이 다음으로 방문해야 할 지점이라면 Queue의 맨 앞에 위치한 값을 제거(popleft)
- 도착지점에 도착했을 때 Queue가 모두 비워졌다면, 즉 순서대로 모두 방문했다면 정답 카운팅
위 방법으로 풀이했었는데, 다른 스터디원분들의 풀이를 참고해본 결과 Queue를 사용하지 않고 DFS 함수의 매개변수로 방문해야 하는 배열의 Index를 전달해주는 방식으로도 풀이할 수 있을 것 같다.
'Algorithm 💡 > DFS' 카테고리의 다른 글
[소프티어 6275번] 로봇이 지나간 경로(HSAT 1회 정기 코딩 인증평가 기출) (0) | 2024.06.27 |
---|---|
[소프티어 7727번] 함께하는 효도 (0) | 2024.06.24 |
[소프티어 6248번] 출퇴근길 (1) | 2024.06.15 |
[백준 1240번] 노드사이의 거리 (1) | 2024.01.08 |
[프로그래머스 PCCP 모의고사 2-4번] 수레 (0) | 2023.11.18 |