본문 바로가기
Develop/Python + SWEA

[SW Expert Academy] 5105. 미로의 거리

by Tarra 2022. 3. 15.

5105. 미로의 거리


문제)

 

NxN 크기의 미로에서 출발지 목적지가 주어진다.

이때 최소 몇 개의 칸을 지나면 출발지에서 도착지에 다다를 수 있는지 알아내는 프로그램을 작성하시오.

경로가 있는 경우 출발에서 도착까지 가는데 지나야 하는 최소한의 칸 수를, 경로가 없는 경우 0을 출력한다.

다음은 5x5 미로의 예이다. 1은 벽, 0은 통로를 나타내며 미로 밖으로 벗어나서는 안된다.

13101
10101
10101
10101
10021

마지막 줄의 2에서 출발해서 0인 통로를 따라 이동하면 맨 윗줄의 3에 5개의 칸을 지나 도착할 수 있다.


[입력]

첫 줄에 테스트 케이스 개수 T가 주어진다.  1<=T<=50

다음 줄부터 테스트 케이스의 별로 미로의 크기 N과 N개의 줄에 걸쳐 미로의 통로와 벽에 대한 정보가 주어진다. 5<=N<=100

0은 통로, 1은 벽, 2는 출발, 3은 도착이다.

[출력]

각 줄마다 "#T" (T는 테스트 케이스 번호)를 출력한 뒤, 답을 출력한다.

 

 

 

 

풀이)

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
32
33
34
35
36
from collections import deque
def BFS():
    global g, answer
 
    di = [-1100]
    dj = [00-11]
 
    while queue:
        a, b = queue.popleft()
        for i in range(4):
            x = a + di[i]
            y = b + dj[i]
            if -1 < x < n and -1 < y < n and g[x][y] != '1':
                if g[x][y] == '3':
                    answer = min(answer, int(g[a][b]))
                    return
                if g[x][y] == '0':
                    g[x][y] = int(g[a][b]) + 1
                    queue.append([x, y])
 
= int(input())
for _ in range(T):
 
    n = int(input())
    g = [list(input()) for i in range(n)]
    queue = deque()
    for i in range(n):
        for j in range(n):
            if g[i][j] == "2":
                queue.append([i, j])
    answer = 1000000
    BFS()
    if answer == 1000000:
        print(f'#{_ + 1} 0')
    else:
        print(f'#{_ + 1} {answer - 2}')
cs

문제 출처 : https://swexpertacademy.com/main/main.do

 

SW Expert Academy

SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!

swexpertacademy.com

※ SW Expert 아카데미는 원칙적으로 문제를 무단 복제하는 것을 금지합니다.

학습용으로 문제를 가져왔으나, 문제가 될 시 수정 및 삭제하겠습니다.