欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Hero

程序员文章站 2022-05-20 16:45:05
...

题目描述
500年前,nowcoder是我国最卓越的剑客。他英俊潇洒,而且机智过人_。 突然有一天,nowcoder 心爱的公主被魔王困在了一个巨大的迷宫中。nowcoder 听说这个消息已经是两天以后了,他知道公主在迷宫中还能坚持T天,他急忙赶到迷宫,开始到处寻找公主的下落。 时间一点一点的过去,nowcoder 还是无法找到公主。最后当他找到公主的时候,美丽的公主已经死了。从此nowcoder 郁郁寡欢,茶饭不思,一年后追随公主而去了。T_T 500年后的今天,nowcoder 托梦给你,希望你帮他判断一下当年他是否有机会在给定的时间内找到公主。 他会为你提供迷宫的地图以及所剩的时间T。请你判断他是否能救出心爱的公主。
输入描述:
题目包括多组测试数据。
每组测试数据以三个整数N,M,T(00)开头,分别代表迷宫的长和高,以及公主能坚持的天数。
紧接着有M行,N列字符,由".","",“P”,"S"组成。其中
“.” 代表能够行走的空地。
"
" 代表墙壁,redraiment不能从此通过。
“P” 是公主所在的位置。
“S” 是redraiment的起始位置。
每个时间段里redraiment只能选择“上、下、左、右”任意一方向走一步。
输入以0 0 0结束。
输出描述:
如果能在规定时间内救出公主输出“YES”,否则输出“NO”。
示例:
输入
4 4 10
. . . .
. . . .
. . . .
S * * P
0 0 0
输出
YES

题目链接

AC代码:
#include<bits/stdc++.h>
using namespace std;
struct fan{
int x;
int y;
int step;
};
int main()
{
int m, n, t;
int c[4][2] = {-1, 0, 1, 0, 0, -1, 0, 1};
while(cin >> n >> m >> t)
{
if(n == 0 && m == 0 && t == 0) break;
int i, j, xx, yy, xx1, yy1, min = 999999;
char a[1000][1000];
for(i = 0; i < m; i++)
for(j = 0; j < n; j++)
{
cin >> a[i][j];
if(a[i][j] == ‘S’) {xx = i; yy = j;a[i][j] = ‘’;}
else if(a[i][j] == ‘P’){xx1 = i; yy1 = j;}
}
fan p;
p.x = xx;
p.y = yy;
p.step = 0;
queue q;
q.push§;
while(!q.empty())
{ p = q.front();
q.pop();
if(p.x == xx1 && p.y == yy1)
{
min = p.step;
break;
}
for(i = 0; i < 4; i++)
{
fan k;
k.x = p.x + c[i][0];
k.y = p.y + c[i][1];
k.step = p.step + 1;
if(k.x >= 0 && k.x < m && k.y >= 0 && k.y < n && a[k.x][k.y] != '
’)
{
q.push(k);
a[k.x][k.y] = ‘*’;

       }
   }

}
if(min <= t) cout<<"YES"<<endl;
else cout<<"NO"<<endl;
}

return 0;
}

相关标签: bfs深度优先搜索