Description
500年前,Jesse是我国最卓越的剑客。他英俊潇洒,而且机智过人^_^。
突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中。Jesse听说这个消息已经是两天以后了,他知道公主在迷宫中还能坚持T天,他急忙赶到迷宫,开始到处寻找公主的下落。
时间一点一点的过去,Jesse还是无法找到公主。最后当他找到公主的时候,美丽的公主已经死了。从此Jesse郁郁寡欢,茶饭不思,一年后追随公主而去了。T_T
500年后的今天,Jesse托梦给你,希望你帮他判断一下当年他是否有机会在给定的时间内找到公主。
他会为你提供迷宫的地图以及所剩的时间T。请你判断他是否能救出心爱的公主。
突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中。Jesse听说这个消息已经是两天以后了,他知道公主在迷宫中还能坚持T天,他急忙赶到迷宫,开始到处寻找公主的下落。
时间一点一点的过去,Jesse还是无法找到公主。最后当他找到公主的时候,美丽的公主已经死了。从此Jesse郁郁寡欢,茶饭不思,一年后追随公主而去了。T_T
500年后的今天,Jesse托梦给你,希望你帮他判断一下当年他是否有机会在给定的时间内找到公主。
他会为你提供迷宫的地图以及所剩的时间T。请你判断他是否能救出心爱的公主。
Input
题目包括多组测试数据。
每组测试数据以三个整数N,M,T(0 < N,M <= 20)开头,
分别代表迷宫的长和高,以及公主能坚持的天数。
紧接着有M行,N列字符,由".","*","P","S"组成。其中
"." 代表能够行走的空地。
"*" 代表墙壁,Jesse不能从此通过。
"P" 是公主所在的位置。
"S" 是Jesse的起始位置。
每个时间段里Jesse只能选择“上、下、左、右”任意一方向走一步。
输入以0 0 0结束。
每组测试数据以三个整数N,M,T(0 < N,M <= 20)开头,
分别代表迷宫的长和高,以及公主能坚持的天数。
紧接着有M行,N列字符,由".","*","P","S"组成。其中
"." 代表能够行走的空地。
"*" 代表墙壁,Jesse不能从此通过。
"P" 是公主所在的位置。
"S" 是Jesse的起始位置。
每个时间段里Jesse只能选择“上、下、左、右”任意一方向走一步。
输入以0 0 0结束。
Output
如果能在规定时间内救出公主输出“YES”,否则输出“NO”。
Sample Input
4 4 10 .... .... .... S**P 0 0 0
Sample Output
YES
思路:
没啥好说的 广度优先搜索 不明白的翻数据结构图那部分
参考代码;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
#include<stdio.h> #include<string.h> #define WALL -1 #define RODE 1000000 int
nx[50000],ny[50000],movex[4]={1,-1,0,0},movey[4]={0,0,1,-1},map[100][100];
void
bfs( int
sx, int
sy)
{ int
front = 0,rear = 1;
nx[0] = sx;
ny[0] = sy;
map[sx][sy] = 0;
while (front < rear)
{
int
i;
for (i = 0;i < 4;i++)
{
int
newx = nx[front] + movex[i],newy = ny[front] + movey[i];
if (map[newx][newy] != WALL && map[nx[front]][ny[front]] + 1 < map[newx][newy])
{
map[newx][newy] = map[nx[front]][ny[front]] + 1;
nx[rear] = newx;
ny[rear] = newy;
rear++;
}
}
front++;
}
} int
main()
{ //freopen("data.in","r",stdin);
int
px,py,sx,sy,n,m,t,i,j;
while ( scanf ( "%d%d%d" ,&n,&m,&t) && n != 0)
{
getchar ();
memset (map,WALL, sizeof (map));
for (i = 0;i < m;i++)
{
for (j = 0;j < n;j++)
{
char
temp;
scanf ( "%c" ,&temp);
if (temp == ‘*‘ ) map[i][j] = WALL;
else
map[i][j] = RODE;
if (temp == ‘S‘ ) sx = i,sy = j;
if (temp == ‘P‘ ) px = i,py = j;
}
getchar ();
}
bfs(sx,sy);
int
ans = map[px][py];
if (ans <= t) puts ( "YES" );
else
puts ( "NO" );
}
return
0;
} |