PS (C, C++)
[백준/C++] 6593 상범 빌딩
최연재
2024. 11. 15. 20:39
https://www.acmicpc.net/problem/6593
코드
#include <iostream>
#include <queue>
#include <cstring>
using namespace std;
#define MAX 31
#define FASTIO ios::sync_with_stdio(false); cin.tie(NULL);
typedef pair<pair<int, int>, pair<int, int>> pii;
int dx[6] = { 0, 0, 1, -1, 0, 0 };
int dy[6] = { 1, -1, 0, 0, 0, 0 };
int dz[6] = { 0, 0, 0, 0, 1, -1 };
int l, r, c;
char arr[MAX][MAX][MAX];
bool visit[MAX][MAX][MAX];
queue<pii> q;
void init() {
memset(arr, '#', sizeof(arr));
memset(visit, false, sizeof(visit));
q = queue<pii>();
}
void bfs() {
while (!q.empty()) {
int z = q.front().first.first;
int y = q.front().first.second;
int x = q.front().second.first;
int t = q.front().second.second;
q.pop();
if (arr[z][y][x] == 'E') {
cout << "Escaped in " << t << " minute(s).\n";
return;
}
for (int i = 0, gz, gy, gx; i < 6; i++) {
gz = z + dz[i];
gy = y + dy[i];
gx = x + dx[i];
if (gx >= 0 && gx < c && gy >= 0 && gy < r && gz >= 0 && gz <= l) {
if (visit[gz][gy][gx] || arr[gz][gy][gx] == '#') continue;
q.push({ {gz, gy}, {gx, t+1} });
visit[gz][gy][gx] = true;
}
}
}
cout << "Trapped!\n";
}
int main() {
FASTIO;
while (true) {
cin >> l >> r >> c;
if (l == 0 && r == 0 && c == 0) break;
init();
for (int i = 0; i < l; i++) {
for (int j = 0; j < r; j++) {
for (int k = 0; k < c; k++) {
cin >> arr[i][j][k];
if (arr[i][j][k] == 'S') {
q.push({ {i, j}, {k, 0} });
visit[i][j][k] = true;
}
}
}
}
bfs();
}
return 0;
}
설명
먼저 정육면체 빌딩이므로 3차원 배열로 정보를 저장한다. 이후 3차원 배열을 대상으로 bfs를 돌리면 된다. 테스트 케이스형태인 문제이니 while문 내에 init 함수를 이용해서 데이터를 초기화해주었다.
느낀 점
첫 번째 코드에서는 층별로 한 줄씩 비어 있는 걸 불필요하게 getchar로 처리하려다가 출력초과가 났었다. 두 번째 코드에서는 이 부분을 지워서 제출했고, 틀렸다. 반례 게시판을 둘러보다가 arr 배열도 초기화가 필요하다고 해서 '#'으로 초기화하는 것을 init 함수에 넣어주었다. 굳이 필요성을 못 느꼈었는데, 이제부터는 의식적으로 초기화를 해둬야겠다.