[프로그래머스] 게임 맵 최단거리 - 파이썬/BFS

JinUk Lee·2023년 3월 2일
0

프로그래머스

목록 보기
20/48

https://school.programmers.co.kr/learn/courses/30/lessons/1844

from collections import deque

def bfs(x,y,maps,n,m):
    q = deque([(x,y)])
    graph = [[ 1 for _ in range(m)] for _ in range(n)]
    dx = [1,-1,0,0]
    dy = [0,0,1,-1]

    while q:
        now_x,now_y = q.popleft()

        for i in range(4):
            nx = now_x + dx[i]
            ny = now_y + dy[i]

            if 0<=nx<n and 0<=ny<m and maps[nx][ny]==1 and graph[nx][ny]==1:
                graph[nx][ny] = graph[now_x][now_y] +1
                q.append((nx,ny))

    return graph[n-1][m-1]


def solution(maps):
    n = len(maps)
    m = len(maps[0])
    answer = bfs(0,0,maps,n,m)
    if answer ==1:
        answer = -1

    return answer

전형적인 2차원 그래프에서 BFS로 최단거리를 구하는 문제다.

상대진영에 도달할 방법이 없는 경우 graph의 값이 디폴트값인 1이므로 -1로 바꿔준다.

profile
개발자 지망생

0개의 댓글