必对
2024-12-29 11:25:45
发布于:浙江
#include <iostream>
#include <cstring>
#include <queue>
using namespace std;
const int max_n = 55;
// 六个拓展方向
int dx[] = {1, -1, 0, 0, 0, 0};
int dy[] = {0, 0, 1, -1, 0, 0};
int dz[] = {0, 0, 0, 0, 1, -1};
int a, b, c, t;
int mp[max_n][max_n][max_n];
int st[max_n][max_n][max_n];
struct Node {
int x, y, z, step;
};
// 检测坐标是否符合要求
int check(int i, int j, int k)
{
if (i <= 0 || j <= 0 || k <= 0 || i > a || j > b || k > c || mp[i][j][k])
return 0;
return 1;
}
int bfs(int x, int y, int z) {
queue<Node> Q;
Q.push({x, y, z, 0});
st[x][y][z] = 1;
while (!Q.empty()) {
Node p = Q.front();
Q.pop();
if (p.x == a && p.y == b && p.z == c && p.step <= t)
return p.step;
for (int i = 0; i < 6; i++) {
Node q = {p.x + dx[i], p.y + dy[i], p.z + dz[i], p.step + 1};
if (!st[q.x][q.y][q.z] && check(q.x, q.y, q.z)) {
st[q.x][q.y][q.z] = 1;
Q.push(q);
}
}
}
return -1;
}
int main() {
int T;
scanf("%d", &T);
while (T--) {
memset(mp, 0, sizeof(mp));
memset(st, 0, sizeof(st));
scanf("%d%d%d%d", &a, &b, &c, &t);
for (int i = 1; i <= a; i++)
for (int j = 1; j <= b; j++)
for (int k = 1; k <= c; k++)
scanf("%d", &mp[i][j][k]);
printf("%d\n", bfs(1, 1, 1));
}
return 0;
}
这里空空如也
有帮助,赞一个