Hero
题目描述
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;
}
上一篇: dfs+回溯写题两种思路
下一篇: 695. 岛屿的最大面积
推荐阅读
-
BZOJ3864: Hero meet devil(dp套dp)
-
锐龙9 5950X烤机全核频率最高!ROG CROSSHAIR VIII DARK HERO评测
-
硕大散热器亮眼!ROG MAXIMUS XIII HERO主板图赏
-
罗技G PRO无线游戏鼠标体验:新HERO传感器表现全面
-
罗技推出G502 HERO英雄联盟限量版:售价549元
-
HDU 4310 Hero【贪心】
-
Java 设计一个Hero二叉树,HeroNode. 可以向这个英雄二叉树插入不同的Hero对象,并且按照Hero的血量升排序。 随机生成10个Hero对象,每个Hero对象都有不同的血量值,插
-
angular的hero例子(代码)
-
3499元 华硕ROG Maximus XI Hero(Wi-Fi)主板图赏
-
英特尔推出HERO智能机器人平台合作伙伴计划