본문 바로가기

Algorithm & Data Structure

백준 - 7576번(BFS)

728x90
반응형

https://www.acmicpc.net/problem/7576

 

7576번: 토마토

첫 줄에는 상자의 크기를 나타내는 두 정수 M,N이 주어진다. M은 상자의 가로 칸의 수, N은 상자의 세로 칸의 수를 나타낸다. 단, 2 ≤ M,N ≤ 1,000 이다. 둘째 줄부터는 하나의 상자에 저장된 토마토

www.acmicpc.net

 

import sys
from collections import deque

n,m = map(int,sys.stdin.readline().split())

arr = []
for i in range(m):
    arr.append(list(map(int,sys.stdin.readline().split())))

res = 0
q = deque()

for i in range(m):
    for j in range(n):
        if arr[i][j] == 1: #이미 익은 토마토가 시작지점
            q.append([i,j])
            #이미 익은 토마토가 1개 이상인 경우도 있으니 break 하면 안됨

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]

            #arr의 범위를 넘지않고 익지않은 토마토(0)과 만날때
            if 0<= nx < m and 0<= ny < n and arr[nx][ny] == 0:
                arr[nx][ny] = arr[x][y] + 1
                q.append([nx,ny]) #q에 새로운 좌표 추가
BFS()

for i in range(len(arr)):
    for j in range(len(arr[i])):
        if arr[i][j] == 0: #익지않은 토마토가 존재할때
            print(-1)
            sys.exit() #프로그램 종료

        elif arr[i][j] > res:
            res = arr[i][j] #최대값 찾기

print(res-1) #시작하는 arr[i][j] 값이 1이기때문에 최종적으로 답에서 1빼주기

 

처음부터 익어 있던 토마토를 q에 담아준다. 여러 개일 가능성이 있다.

상, 하, 좌, 우 탐색을 해주면서 arr의 범위를 벗어나지 않고 익지 않은 토마토를 만날 경우

누적 횟수에 1을 더해주고 다시 q에 담아준다.

이를 BFS 탐색을 한다.

익지 않은 토마토가 탐색 후에도 존재할 경우 -1을 출력하고 프로그램 종료,

그렇지 않은 경우 최댓값을 찾아서 -1을 해준후 출력한다.

728x90
반응형

'Algorithm & Data Structure' 카테고리의 다른 글

백준 - 11729번(재귀)  (0) 2022.04.28
백준 - 16236번(BFS,구현)  (0) 2022.04.10
백준 - 2178번(BFS)  (0) 2022.04.09
백준 - 2606번(DFS,BFS)  (0) 2022.04.09
백준 - 2161번(큐)  (0) 2022.04.01