Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- [sqld]자격증합격
- 프로그래머스
- 피보나치 함수
- python
- Reverse Shuffle Merge
- 구슬탈출2
- Max Array Sum
- Special String Again
- DFS: Connected Cell in a Grid
- BFS: Shortest Reach in a Graph
- 코딩테스트
- Interview Preparation Kit
- 야근지수
- 해커랭크
- programmers
- 머신러닝
- 격파르타 후기
- 격파르타 합격후기
- 파이썬
- Roads and Libraries
- Common Child
- hackerrank
- Find the nearest clone
- Recursion: Davis' Staircase
- 매칭점수
- 격파르타 장점
- 알고리즘
- 백준
- candies
- Algorithm
Archives
- Today
- Total
Archive
[BOJ] 2178. 미로탐색 본문
풀이
- queue를 사용한 BFS문제.
def solution(M, N, m):
rs = 0
visited = [[False for _ in range(N)] for _ in range(M)]
queue = [[0, 0]]
m[0][0] = 1
# 상, 하, 좌, 우
dx = [-1, 1, 0, 0]
dy = [0, 0, -1, 1]
while queue:
x, y = queue.pop(0)
for idx in range(4):
next_x = x + dx[idx]
next_y = y + dy[idx]
if 0 <= next_x < N and 0 <= next_y < M and m[next_x][next_y] == '1':
if type(m[next_x][next_y]) == int:
m[next_x][next_y] = min(m[x][y]+1, m[next_x][next_y])
else: m[next_x][next_y] = m[x][y]+1
queue.append([next_x, next_y])
return m[N-1][M-1]
import sys
N,M = map(int, sys.stdin.readline().split(' '))
m = []
for _ in range(N):
lst = [i for i in sys.stdin.readline().strip()]
m.append(lst)
print(solution(M, N, m))
'공부 > Algorithm' 카테고리의 다른 글
[BOJ] 1003. 피보나치 함수 (0) | 2021.02.14 |
---|---|
[BOJ] 10451. 순열 사이클 (0) | 2021.02.14 |
[BOJ] 1303. 전쟁-전투 (0) | 2021.02.07 |
[BOJ] 1697 숨바꼭질 (0) | 2021.01.31 |
[BOJ] 1406 에디터 (0) | 2021.01.31 |
Comments