#include <stdio.h>
#define MAX 100*100*100+10
int board[101][101][101];
int x1, y1, x2, y2, N, M, L;
int min = 99999;
typedef struct tomato{
int x; int y; int z;
int day;
}TOMATO;
TOMATO queue[MAX];
int head, tail;
int dx[4] = { 1, 0, -1, 0, 0, 0 };
int dy[4] = { 0, -1, 0, 1, 0, 0 };
int dz[8] = { 0, 0, 0, 0, 1, -1 };
void enqueue(int x, int y, int z, int day);
TOMATO dequeue();
TOMATO popped;
TOMATO Next;
void main(){
int x, y, z, cnt, i, j, k, sum;
sum = 0; cnt = 0;
scanf("%d %d %d", &M, &N, &L);
for (k = 0; k < L; k++){
for (i = 0; i < N; i++){
for (j = 0; j < M; j++){
scanf(" %d", &board[k + 1][i + 1][j + 1]);
if (board[k + 1][i + 1][j + 1] == 1) enqueue(i + 1, j + 1, k +1 , 0);
}
}
}
while (head != tail){
popped = dequeue();
x = popped.x; y = popped.y; cnt = popped.z;
for (i = 0; i < 6; i++){
if (!(x + dx[i] > 0 && x + dx[i] < (N + 1))) continue;
if (!(y + dy[i] > 0 && y + dy[i] < (M + 1))) continue;
if (!(z + dz[i] > 0 && z + dz[i] < (L + M))) continue;
if (board[z+dz[i]][x + dx[i]][y + dy[i]] == 1) continue;
if (board[z + dz[i]][x + dx[i]][y + dy[i]] == -1) continue;
if (board[z + dz[i]][x + dx[i]][y + dy[i]] == 0){
enqueue(x + dx[i], y + dy[i], z+ dz[i], cnt + 1);
}
}
}
min = cnt;
for (k = 0; k < L; k++){
for (i = 0; i < N; i++){
for (j = 0; j < M; j++){
if (board[k + i][i + 1][j + 1] == 0){
min = -1; break;
}
}
}
}
printf("%d", min);
}
void enqueue(int x, int y, int z, int day){
tail++; tail %= MAX;
queue[tail].x = x; queue[tail].y = y; queue[tail].z = z; queue[tail].day = day;
board[z][x][y] = 1;
return;
}
TOMATO dequeue(){
head++; head %= MAX;
TOMATO out;
out.x = queue[head].x; out.y = queue[head].y; out.z = queue[head].z;
return out;
}
Compilation message
cc.cpp:13:33: error: too many initializers for 'int [4]'
int dx[4] = { 1, 0, -1, 0, 0, 0 };
^
cc.cpp:14:33: error: too many initializers for 'int [4]'
int dy[4] = { 0, -1, 0, 1, 0, 0 };
^
cc.cpp:20:11: error: '::main' must return 'int'
void main(){
^
cc.cpp: In function 'int main()':
cc.cpp:24:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%d %d %d", &M, &N, &L);
~~~~~^~~~~~~~~~~~~~~~~~~~~~~~
cc.cpp:28:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf(" %d", &board[k + 1][i + 1][j + 1]);
~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~