https://www.acmicpc.net/problem/7576
이 문제는 시작 지점이 2곳 이상인 좌표를 동시에 BFS 구현하는 문제다.
기존에 풀었던 BFS 유형과 다르게 재귀가 아니라 큐에 토마토 판을 백업해둔 후,
방향좌표로 색칠하고 개수를 세는 문제다.
파이썬 코드
#7576_토마토
import sys
from collections import deque
input = sys.stdin.readline
def bfs():
dx = [-1,1,0,0]
dy = [0,0,-1,1]
while q:
x,y = q.popleft()
for i in range(4):
nx = x + dx[i]
ny = y + dy[i]
if 0<= nx < N and 0 <= ny < M:
if graph[nx][ny]==0:
q.append([nx,ny])
graph[nx][ny]=graph[x][y]+1
q=deque([])
M, N = map(int, input().split())
graph = [list(map(int, input().split())) for _ in range(N)]
path = []
for i in range(N):
for j in range(M):
if graph[i][j]==1:
q.append([i,j])
bfs()
res=0
for i in graph:
for j in i:
if j==0:
print(-1)
exit(0)
res = max(res, max(i))
print(res-1)
'알고리즘 > 백준(BOJ)' 카테고리의 다른 글
[백준/알고리즘] #2750: 수정렬하기 [파이썬(python)/정렬] (0) | 2021.10.18 |
---|---|
[백준/알고리즘] #2468: 안전 영역 [파이썬(python)/DFS/BFS] (1) | 2021.10.06 |
[백준/알고리즘] #5622: 다이얼 [파이썬(python)/문자열] (0) | 2021.10.04 |
[백준/알고리즘] #18352: 특정 거리의 도시 찾기 [파이썬(python)/DFS/BFS] (0) | 2021.10.04 |
[백준/알고리즘] #1890:점프 [파이썬(python)/DFS/BFS] (0) | 2021.10.04 |