알고리즘/C, C++

백준 7569 토마토

2021. 6. 16. 14:58
728x90

https://www.acmicpc.net/problem/7569 <- 문제 풀이 사이트


 

#include <cstdio>
#include <iostream>
#include <queue>
#include <tuple>
 
#define endly "\n"
using namespace std;
 
int d[100][100][100];
bool visited[100][100][100];
 
int dx[] = {1, -1, 0, 0, 0, 0};
int dy[] = {0, 0, 1, -1, 0, 0};
int dz[] = {0, 0, 0, 0, 1, -1};
queue<tuple<int, int, int>> q;

int main() {

    int m, n, h;
    cin >> m >> n >> h;
    bool all_one;
    for (int z = 0; z < h; z++) {
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < m; j++) {
                cin >> d[i][j][z];
                // 0이 입력됐는지 확인
                if (d[i][j][z] == 0) all_one = true;
                if (d[i][j][z] == 1) {
                    q.push(make_tuple(i, j, z));
                    visited[i][j][z] = true;
                }
            }
        }
    }
    // 0의 입력이 없으면
    if (!all_one) {
        printf("0");
        return 0;
    }
    while (!q.empty()) {
        int x, y, z;
        tie(x, y, z) = q.front();
        q.pop();
        for (int k = 0; k < 6; k++) {
            int nx = x + dx[k];
            int ny = y + dy[k];
            int nz = z + dz[k];
            if (nx >= 0 && nx < n && ny >= 0 && ny < m && nz >= 0 && nz < h) {
                if (d[nx][ny][nz] == 0 && !visited[nx][ny][nz]) {
                    q.push(make_tuple(nx, ny, nz));
                    visited[nx][ny][nz] = true;
                    d[nx][ny][nz] = d[x][y][z] + 1;
                }
            }
        }
    }
    int ans = 0;
    for (int z = 0; z < h; z++) {
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < m; j++) {
                if (d[i][j][z] == 0) { // 익지 않은 토마토가 있을 경우
                    printf("-1");
                    return 0;
                }
                if (ans < d[i][j][z]) ans = d[i][j][z];
            }
        }
    }
    printf("%d", ans-1);
    return 0;
}

 

 

 

728x90
저작자표시 비영리 (새창열림)

'알고리즘 > C, C++' 카테고리의 다른 글

백준 11047번 동전 0  (0) 2021.06.20
포인터  (1) 2021.06.04
'알고리즘/C, C++' 카테고리의 다른 글
  • 백준 11047번 동전 0
  • 포인터
나봄하랑
나봄하랑
저의 IT 성장을 담은 블로그 입니다!
나봄하랑
나의 IT 성장일지
나봄하랑
전체
오늘
어제
  • 분류 전체보기 (60)
    • 기능반공부 (26)
      • 서버 (6)
      • 네트워크 (6)
      • 클라우드 컴퓨팅 (12)
      • 기능경기대회 (2)
    • 알고리즘 (7)
      • 자료구조 (4)
      • C, C++ (3)
      • python (0)
    • 해킹 (22)
      • 웹해킹 (7)
      • 리버싱 (7)
      • 시스템해킹 (8)
    • 게임이론 (0)
      • 체스 (0)
      • 마작 (0)
    • 웹개발 (1)
      • 웹(HTML, CSS, JS) (1)
    • 공부 (4)
      • 영어 (3)
      • 과학 (0)
      • 국어 (1)
      • 한국사 (0)

블로그 메뉴

  • 홈
  • 태그
  • 방명록
  • about

공지사항

인기 글

태그

  • 해킹
  • 버그
  • SSM
  • FSB
  • 클컴
  • 서버구축
  • grabcon
  • injection
  • reversing
  • Network
  • Los
  • 스트링
  • 레지스터
  • computing
  • 아마존
  • 리버싱
  • Cloud
  • computting
  • 클라우드
  • BOF
  • CC
  • server
  • 컴퓨팅
  • AWS
  • 네트워크
  • CTF
  • 시스템해킹
  • 모의고사
  • SQL
  • 백준

최근 댓글

최근 글

250x250
hELLO · Designed By 정상우.
나봄하랑
백준 7569 토마토
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.