ye0nn
영차영차
ye0nn
전체 방문자
오늘
어제
  • 분류 전체보기 (61)
    • CS (0)
      • 운영체제 (0)
      • 네트워크 (0)
      • 알고리즘 & 자료구조 (0)
    • 코딩테스트 (48)
      • 프로그래머스 (40)
      • 백준 (8)
    • 프로그래밍 (11)
      • 프론트엔드 (3)
      • 자바스크립트 (0)
      • 스위프트 (7)
      • 파이썬 (1)
    • 취준기록 (1)

인기 글

블로그 메뉴

  • 홈
  • 태그
  • 방명록

티스토리

hELLO · Designed By 정상우.
ye0nn

영차영차

[프로그래머스] Level 2 - 게임 맵 최단거리 (Python)
코딩테스트/프로그래머스

[프로그래머스] Level 2 - 게임 맵 최단거리 (Python)

2022. 6. 9. 13:01

 

 

 

 

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

 

코딩테스트 연습 - 게임 맵 최단거리

[[1,0,1,1,1],[1,0,1,0,1],[1,0,1,1,1],[1,1,1,0,1],[0,0,0,0,1]] 11 [[1,0,1,1,1],[1,0,1,0,1],[1,0,1,1,1],[1,1,1,0,0],[0,0,0,0,1]] -1

programmers.co.kr

 

 

 

 

✅ Solution

  • 최단거리 구하는 문제므로 BFS를 이용한다.

 

 

 

 

✅ Code

from collections import deque

def solution(maps):
    n, m = len(maps), len(maps[0])
    dx = [-1, 1, 0, 0]
    dy = [0, 0, -1, 1]

    queue = deque()
    queue.append((0, 0))

    while queue:
        x, y = queue.popleft()

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

            if 0 <= nx < n and 0 <= ny < m:
                if maps[nx][ny] == 1:
                    maps[nx][ny] = maps[x][y] + 1
                    queue.append((nx, ny))

    return maps[n - 1][m - 1] if maps[n - 1][m - 1] > 1 else -1

 

 

 

 

저작자표시 (새창열림)

'코딩테스트 > 프로그래머스' 카테고리의 다른 글

[프로그래머스] Level 2 - 다리를 지나는 트럭 (Python)  (0) 2022.06.22
[프로그래머스] Level 2 - 위장 (Python)  (0) 2022.06.09
[프로그래머스] Level 2 - 배달 (Python)  (0) 2022.06.09
[프로그래머스] Level 2 - 괄호 회전하기 (Python)  (0) 2022.06.09
[프로그래머스] Level 2 - 짝지어 제거하기 (Python)  (0) 2022.06.04
    '코딩테스트/프로그래머스' 카테고리의 다른 글
    • [프로그래머스] Level 2 - 다리를 지나는 트럭 (Python)
    • [프로그래머스] Level 2 - 위장 (Python)
    • [프로그래머스] Level 2 - 배달 (Python)
    • [프로그래머스] Level 2 - 괄호 회전하기 (Python)
    ye0nn
    ye0nn
    프론트엔드 개발자의 개발기록

    티스토리툴바