Problem B
电子老鼠闯迷宫
时限:1000ms 内存限制:10000K 总时限:3000ms
描述:
有一只电子老鼠被困在如下图所示的迷宫中。这是一个12*12单元的正方形迷宫,黑色部分表示建筑物,白色部分是路。电子老鼠可以在路上向上、下、左、右行走,每一步走一个格子。现给定一个起点S和一个终点T,求出电子老鼠最少要几步从起点走到终点。
输入:
本题包含一个测例。在测例的第一行有四个由空格分隔的整数,分别表示起点的坐标S(x.y)和终点的坐标T(x,y)。从第二行开始的12行中,每行有12个字符,描述迷宫的情况,其中'X'表示建筑物,'.'表示路.
输出:
输出一个整数,即电子老鼠走出迷宫至少需要的步数。
输入样例:
2 9 11 8
XXXXXXXXXXXX
X......X.XXX
X.X.XX.....X
X.X.XX.XXX.X
X.X.....X..X
X.XXXXXXXXXX
X...X.X....X
X.XXX...XXXX
X.....X....X
XXX.XXXX.X.X
XXXXXXX..XXX
XXXXXXXXXXXX
输出样例:
2
#include <iostream>
#include <queue>
using namespace std;
//queue <rec> q;
char s[15][15];
int d[15][15];
int start_x, start_y, end_x, end_y;
struct rec {
int second;
int first;
};
queue <rec> q;
int dx[4] = {0, 0, 1, -1};
int dy[4] = {1, -1, 0, 0};
bool can(int x, int y) {
if (x < 1 || y < 1 || y > 12 || x > 12) {
return false;
}
if (s[x][y] == 'X') {
return false;
}
return true;
}
int main() {
cin >> start_x >> start_y >> end_x >> end_y;
for (int i = 1; i <= 12; i++) {
for (int j = 1; j <= 12; j++) {
cin >> s[i][j];
}
}
memset(d, -1, sizeof(d));
d[start_x][start_y] = 0;
rec temp;
temp.first = start_x;
temp.second = start_y;
q.push(temp);
while (q.size()) {
rec now = q.front();
q.pop();
for (int i = 0; i < 4; i++) {
rec next;
next.first = now.first + dx[i];
next.second = now.second + dy[i];
if (!can(next.first, next.second)) {
continue;
}
if (d[next.first][next.second] == -1) {
d[next.first][next.second] = d[now.first][now.second] + 1;
q.push(next);
}
}
}
cout << d[end_x][end_y] << endl;
return 0;
}