미세먼지를 제거하기 위해 구사과는 공기청정기를 설치하려고 한다. 공기청정기의 성능을 테스트하기 위해 구사과는 집을 크기가 R×C인 격자판으로 나타냈고, 1×1 크기의 칸으로 나눴다. 구사과는 뛰어난 코딩 실력을 이용해 각 칸 (r, c)에 있는 미세먼지의 양을 실시간으로 모니터링하는 시스템을 개발했다. (r, c)는 r행 c열을 의미한다.
공기청정기는 항상 1번 열에 설치되어 있고, 크기는 두 행을 차지한다. 공기청정기가 설치되어 있지 않은 칸에는 미세먼지가 있고, (r, c)에 있는 미세먼지의 양은 Ar,c이다.
1초 동안 아래 적힌 일이 순서대로 일어난다.
미세먼지가 확산된다. 확산은 미세먼지가 있는 모든 칸에서 동시에 일어난다.
공기청정기가 작동한다.
공기청정기에서 부는 바람은 미세먼지가 없는 바람이고, 공기청정기로 들어간 미세먼지는 모두 정화된다.
왼쪽과 오른쪽에 칸이 없기 때문에, 두 방향으로만 확산이 일어났다.
인접한 네 방향으로 모두 확산이 일어난다.
공기청정기가 있는 칸으로는 확산이 일어나지 않는다.
공기청정기의 바람은 다음과 같은 방향으로 순환한다.
방의 정보가 주어졌을 때, T초가 지난 후 구사과의 방에 남아있는 미세먼지의 양을 구해보자.
첫째 줄에 R, C, T (6 ≤ R, C ≤ 50, 1 ≤ T ≤ 1,000) 가 주어진다.
둘째 줄부터 R개의 줄에 Ar,c (-1 ≤ Ar,c ≤ 1,000)가 주어진다. 공기청정기가 설치된 곳은 Ar,c가 -1이고, 나머지 값은 미세먼지의 양이다. -1은 2번 위아래로 붙어져 있고, 가장 윗 행, 아랫 행과 두 칸이상 떨어져 있다.
첫째 줄에 T초가 지난 후 구사과 방에 남아있는 미세먼지의 양을 출력한다.
spreadFineDust
와 turnAirCleaner
함수를 번갈아가면서 실행시켰다.spreadFineDust
는 미세먼지가 존재하는 칸의 상하좌우에 (해당 칸의 미세먼지) / 5
한 값을 확산시키고 자신의 칸에는 확산된 미세먼지만큼 빼주면 된다.turnAirCleaner
는 위쪽과 아래쪽이 나뉜다.null
#include <iostream>
#include <algorithm>
#include <vector>
#include <queue>
using namespace std;
int n, m, t;
int map[50][50];
int airCleanerX = -1;
int dx[] = {0, -1, 0, 1};
int dy[] = {1, 0, -1, 0};
void spreadFineDust() {
int temp[50][50] = {0, };
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
if (map[i][j] > 0) {
int mountOfSpreadDust = 0;
for (int k = 0; k < 4; k++) {
int nx = i + dx[k];
int ny = j + dy[k];
if (nx < 0 | nx >= n || ny < 0 || ny >= m) continue;
if (map[nx][ny] == -1) continue;
temp[nx][ny] += map[i][j] / 5;
mountOfSpreadDust += map[i][j] / 5;
}
temp[i][j] -= mountOfSpreadDust;
}
}
}
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
if (map[i][j] == -1) continue;
map[i][j] += temp[i][j];
}
}
}
void turnAirCleaner() {
for (int i = airCleanerX -1; i > 0; i--) {
map[i][0] = map[i-1][0];
}
for (int i = 0; i < m - 1; i++) {
map[0][i] = map[0][i + 1];
}
for (int i = 0; i < airCleanerX; i++) {
map[i][m - 1] = map[i + 1][m - 1];
}
for (int i = m - 1; i > 1; i--) {
map[airCleanerX][i] = map[airCleanerX][i - 1];
}
map[airCleanerX][1] = 0;
for (int i = airCleanerX + 2; i < n - 1; i++) {
map[i][0] = map[i + 1][0];
}
for (int i = 0; i < m - 1; i++) {
map[n - 1][i] = map[n - 1][i + 1];
}
for (int i = n - 1; i > airCleanerX + 1; i--) {
map[i][m - 1] = map[i - 1][m - 1];
}
for (int i = m - 1; i > 1; i--) {
map[airCleanerX + 1][i] = map[airCleanerX + 1][i - 1];
}
map[airCleanerX + 1][1] = 0;
}
int main() {
cin.tie(NULL);
ios_base::sync_with_stdio(false);
cin >> n >> m >> t;
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
cin >> map[i][j];
if (airCleanerX == -1 && map[i][j] == -1) {
airCleanerX = i;
}
}
}
for (int second = 0; second < t; second++) {
spreadFineDust();
turnAirCleaner();
}
int answer = 0;
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
if (map[i][j] <= 0) continue;
answer += map[i][j];
}
}
cout << answer;
}