반응형
250x250
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 |
Tags
- 코드
- 토마토
- 자료구조
- 코딩테스트
- it
- 백준 백트랙킹 파이썬
- 백준 토마토 파이썬
- BFS
- 정보처리기사
- python
- 백준 그래프 탐색 파이썬
- 정보처리기사 실기
- 그리디
- 알고리즘
- 백준
- 정보처리기사 실기 시험
- BOJ
- dfs
- 프로그래머스 파이썬
- 2022년 정보처리기사 실기
- 프로그래머스
- 파이썬
- 자바
- 백준 백트랙킹
- 백준 그래프 이론 파이썬
- 코딩
- 2022년 정보처리기사 실기 가답안
- 백준 N-Queens
- 프로그래밍
- 2022년 정보처리기사 실기 1회 가답안
Archives
- Today
- Total
코딩,안되면 될때까지
[백준 7569번-토마토]-파이썬 본문
728x90
반응형
solved.ac 난이도 : GOLD4
백준 7569번- 파이썬 풀이
<문제>
https://www.acmicpc.net/problem/7569
<풀이>-그래프이론,너비우선탐색,그래프 탐색
이 문제는 필자의 블로그에 있던 기존 토마토 문제에 좌표하나만 추가하면 된다. 즉 ,2차원 리스트를 사용하는 풀이에서 2차원 리스트를 3차원 리스트로만 바꿔주면 된다. 3차원리스트의 선언방법은 다음과 같다.
tomato1 = [[list(map(int,input().split())) for i in range(n)] for depth in range(h)]
자세한 풀이는 다음 링크를 참고하자
https://hae-sooo97.tistory.com/55
<코드>-파이썬
from collections import deque
m,n,h = map(int,input().split())
tomato1 = [[list(map(int,input().split())) for i in range(n)] for depth in range(h)]
dx = [-1,0,1,0,0,0]
dy = [0,1,0,-1,0,0]
dh = [0,0,0,0,-1,1]
queue = deque()
for i in range(h):
for j in range(n):
for k in range(m):
if tomato1[i][j][k]==1:
queue.append([i,j,k])
while queue:
z,x,y = queue.popleft()
for i in range(6):
nz = z+dh[i]
nx = x+dx[i]
ny = y+dy[i]
if 0<=nx<n and 0<=ny<m and 0<=nz<h:
if tomato1[nz][nx][ny]==0:
tomato1[nz][nx][ny] = tomato1[z][x][y]+1
queue.append([nz,nx,ny])
flag = False
for i in tomato1:
for j in i:
for k in j:
if k == 0:
flag = True
break
if flag:
print(-1)
else:
max_value = 0
for i in range(h):
for j in range(n):
for k in range(m):
max_value = max(max_value,tomato1[i][j][k])
print(max_value-1)
728x90
반응형
'백준 > 백준-파이썬' 카테고리의 다른 글
[백준 1748번-수 이어쓰기1]-파이썬 (3) | 2022.04.23 |
---|---|
[백준 1449번-수리공 항승]-파이썬 (5) | 2022.04.19 |
[백준 2206번-벽 부수고 이동하기]-파이썬 (10) | 2022.04.14 |
[백준 1439번-뒤집기]-파이썬 (5) | 2022.04.13 |
[백준 7576번-토마토]-파이썬 (5) | 2022.04.12 |
Comments