반응형
250x250
Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- dfs
- 싸피 7기 입학식
- 프로그래머스
- bfs
- SSAFY 입학식
- pytorch
- 백준7576 bfs
- ssafy 7기
- SSAFY
- 삼성 청년 SW 아카데미
- SWEA
- 삼성청년sw아카데미
- Learning
- ssafy 7기 합격
- 알고리즘
- 이코테
- SSAFY 8기
- React
- git
- 코딩교육
- 백준
- 프로그래머스 고득점 kit
- 코딩 교육
- 웹 표준 사이트 만들기
- SSAFYcial
- 전이학습
- ssafy 7기 교수님
- DenseNet
- 유니온 파인드
- DP
Archives
- Today
- Total
개미의 개열시미 프로그래밍
[알고리즘] 백준7576 토마토 - 파이썬 본문
728x90
반응형
어제 점심에 풀었던 문제였지만 졸업 프로젝트 포스터를 만들고 다른 과목 발표자료도 만드느라 이제야 글을 올린다..
https://www.acmicpc.net/problem/7576
풀이코드
from collections import deque
from sys import stdin
m, n = map(int, stdin.readline().split()) # m가로, n세로
graph = []
for _ in range(n):
graph.append(list(map(int, stdin.readline().split())))
# print(graph)
# 상하좌우
xh = [-1, 1, 0, 0]
yw = [0, 0, -1, 1]
def bfs():
while queue:
x, y = queue.popleft()
for d in range(4):
xx = xh[d] + x
yy = yw[d] + y
if 0 <= xx < n and 0 <= yy <m and graph[xx][yy] == 0:
graph[xx][yy] = graph[x][y] + 1
queue.append([xx, yy])
queue = deque()
for i in range(n):
for j in range(m):
if graph[i][j] == 1:
queue.append(([i,j])) # bfs함수 내부가 아닌 여기서 append를 해준다!!
bfs()
# print(graph) # bfs 수행 후 graph 점검
result = -2 # 임의로 설정한 최소값
flag = False # graph 탐색시 0인 값이 있다면 -1 출력위함
for row in graph:
for r in row:
if r == 0:
flag = True
result = max(result, r) # 최대값
if flag == True: print(-1)
elif result == -1: print(0) # 모두 익은 경우 : 0출력
else: print(result-1) # 결과 출력
문제풀이
: 이번에도 당연히 이차원 배열 graph [n-1][m-1]까지의 최소거리를 구하는 문제인 줄 알아서 어디가 문제인지 모르고 시간이 오래 걸렸던 문제였다.
그전에 풀었던 문제와 달리 이번 토마토 문제에서는 큐를 bfs함수 내부가 아닌 밖에 선언을 하고 이차원 배열을 돌면서 토마토가 존재하는 '1'인 인덱스들을! 큐에 append 해주어야 한다.
그렇지 않고 큐를 bfs함수 내부에서 생성하여 전에 문제를 풀 듯 큐에 하나의 인덱스만 넣고 돌리면 당연히 graph [n-1][m-1]까지의 최소거리를 구하는 코드가 되어버린다.
위 예제 입력 3)을 예로 들면 반복문을 돌면서 큐에 '1'인 인덱스인 0,0과 3,5가 담긴다 => deque([0,0]. [3,5])
그리고 bfs()를 수행하면 [0,0] out [0,1] in => deque([3,5], [0,1]) 다음은 [3,5] out [2, 5] in => deque([[0,1], [2,5]) 이런 식으로 양쪽에서 좁혀오게 된다.
728x90
반응형
'알고리즘 > DFS, BFS, 백트래킹' 카테고리의 다른 글
[알고리즘] 백준1697 숨바꼭질 - 파이썬 (0) | 2021.06.07 |
---|---|
[알고리즘] 백준7569 토마토 - 파이썬 (0) | 2021.06.06 |
[알고리즘] 백준2178 미로탐색 - 파이썬 (0) | 2021.06.02 |
[알고리즘] 백준 1012 유기농 배추 - 파이썬 (0) | 2021.06.01 |
[알고리즘] 백준 2667 단지번호붙이기 - 파이썬 (0) | 2021.06.01 |
Comments