Hero In Maze
Hero In Maze
描写叙述
500年前,Jesse是我国最卓越的剑客。
他英俊潇洒,并且机智过人^_^。
突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中。
Jesse听说这个消息已经是两天以后了,他知道公主在迷宫中还能坚持T天,他急忙赶到迷宫,開始到处寻找公主的下落。
时间一点一点的过去。Jesse还是无法找到公主。
最后当他找到公主的时候,漂亮的公主已经死了。从此Jesse郁郁寡欢,茶饭不思。一年后追随公主而去了。T_T
500年后的今天,Jesse托梦给你,希望你帮他推断一下当年他是否有机会在给定的时间内找到公主。
他会为你提供迷宫的地图以及所剩的时间T。
请你推断他能否救出心爱的公主。
输入
题目包含多组測试数据。
每组測试数据以三个整数N,M,T(0<n, m≤20, t>0)开头,分别代表迷宫的长和高,以及公主能坚持的天数。
紧接着有M行。N列字符,由".","*"。"P","S"组成。
当中
"." 代表可以行走的空地。
"*" 代表墙壁。Jesse不能从此通过。
"P" 是公主所在的位置。
"S" 是Jesse的起始位置。
每一个时间段里Jesse仅仅能选择“上、下、左、右”随意一方向走一步。
输入以0 0 0结束。
输出
假设能在规定时间内救出公主输出“YES”,否则输出“NO”。
例子输入
....
....
....
S**P
0 0 0
例子输出
AC代码例如以下
#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
#include <cmath>
#include <queue>
#define M 1000005
#define ll long long
using namespace std; int DTx[4]={-1,0,1,0};
int DTy[4]={0,1,0,-1};
char map[25][25];
int dp[25][25];
int x,y,X,Y;
int minn;
int n,m,t; struct H{
int x,y;
int time;
}; int bfs(int h,int z)
{
int i,j;
queue <H> q;
H a,b,c;
a.x=h;
a.y=z;
a.time=0;
q.push(a);
while(!q.empty())
{
b=q.front();
q.pop();
if(b.x==X&&b.y==Y)
return b.time;
for(i=0;i<4;i++)
{
c.x=b.x+DTx[i];
c.y=b.y+DTy[i];
if(c.x>=0&&c.x<m&&c.y>=0&&c.y<n&&!dp[c.x][c.y])
{
dp[c.x][c.y]=1;
c.time=b.time+1;
q.push(c);
}
}
}
return 0;
} int main()
{
int i,j;
while(~scanf("%d%d%d",&n,&m,&t)&&(n||m||t))
{
memset(dp,0,sizeof dp);
for(i=0;i<m;i++)
cin>>map[i];
for(i=0;i<m;i++)
for(j=0;j<n;j++)
if(map[i][j]=='S')
{x=i;y=j;dp[i][j]=1;}
else if(map[i][j]=='P')
{X=i;Y=j;}
else if(map[i][j]=='*')
dp[i][j]=1; //printf("%d %d %d %d\n",x,y,X,Y);
minn=bfs(x,y);
/*for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
cout<<dp[i][j]<<" ";
cout<<endl;
}*/
//printf("%d\n",minn);
if(minn==0)
{
printf("NO\n");
continue;
}
if(minn<=t)
printf("YES\n");
else printf("NO\n");
}
return 0;
}
Hero In Maze的更多相关文章
- 1006: Hero In Maze
1006: Hero In Maze 时间限制: 1000 Sec 内存限制: 64 MB提交: 417 解决: 80[提交][状态][讨论版][命题人:外部导入] 题目描述 500年前,Jess ...
- YTU 1006: Hero In Maze
1006: Hero In Maze 时间限制: 1000 Sec 内存限制: 64 MB 提交: 72 解决: 22 题目描述 500年前,Jesse是我国最卓越的剑客.他英俊潇洒,而且机智过人 ...
- TZOJ 3305 Hero In Maze II(深搜)
描述 500年前,Jesse是我国最卓越的剑客.他英俊潇洒,而且机智过人^_^.突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中.Jesse听说这个消息已经是两天以后了,他急忙赶到迷宫,开 ...
- Hero In Maze(BFS广搜)
Description 500年前,Jesse是我国最卓越的剑客.他英俊潇洒,而且机智过人^_^.突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中.Jesse听说这个消息已经是两天以后了, ...
- TOJ 1005 Hero In Maze (深搜)
描述 500年前,Jesse是我国最卓越的剑客.他英俊潇洒,而且机智过人^_^. 突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中.Jesse听说这个消息已经是两天以后了,他知道公主在迷宫 ...
- 【TOJ 3305】Hero In Maze II
描述 500年前,Jesse是我国最卓越的剑客.他英俊潇洒,而且机智过人^_^.突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中.Jesse听说这个消息已经是两天以后了,他急忙赶到迷宫,开 ...
- 3305: Hero In Maze II (优先队列+bfs)
Description 500年前,Jesse是我国最卓越的剑客.他英俊潇洒,而且机智过人^_^.突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中.Jesse听说这个消息已经是两天以后了, ...
- ACM-Hero In Maze
Hero In Maze 时间限制(普通/Java):1000MS/10000MS 运行 ...
- 杭电ACM分类
杭电ACM分类: 1001 整数求和 水题1002 C语言实验题——两个数比较 水题1003 1.2.3.4.5... 简单题1004 渊子赛马 排序+贪心的方法归并1005 Hero In Maze ...
随机推荐
- Linux 指令的快捷键
- NYOJ 995 硬币找零
硬币找零 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 在现实生活中,我们经常遇到硬币找零的问题,例如,在发工资时,财务人员就需要计算最少的找零硬币数,以便他们能从 ...
- Codeforces Round #402 (Div. 2) A+B+C+D
Codeforces Round #402 (Div. 2) A. Pupils Redistribution 模拟大法好.两个数列分别含有n个数x(1<=x<=5) .现在要求交换一些数 ...
- VS链接错误: LNIK1123
问题:编译一个VS工程程序,出现连接错误:"LNK1123: 转换到 COFF 期间失败: 文件无效或损坏" 原因分析:连接器LNK是通过调用cvtres.exe完成文件向coff ...
- Jackson工具类(各种转换)
首先要在项目中引入jackson的jar包(在此不做说明) 下面直接上代码 public class JacksonUtils { private final static ObjectMapper ...
- ElasticSearch API 之 DELETE
删除API,可以根据特定的ID删除文档. $ curl -XDELETE 'http://localhost:9200/website/blog/AVbkih8AltSLRRB7XAun' 会返回下面 ...
- JSP表单提交中文乱码
简要笔记:由于jsp默认表单提交编码方式是:ISO-8859-1,而我们需要的是utf-8或者是gbk码,故需要转化. 具体方法是:在表单处理文件中,将获取到的变量进行转换. String userN ...
- 洛谷 P1756 最小花费
题目背景 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少钱使得转账后B收到100元 ...
- 基于CI框架的管理系统
1:ci框架是有入口文件的,前端和后台入口文件(index.php,admin.php):里面修改$application_folder = 'application/home': 2:项目基本都是在 ...
- electron 自定义菜单
快捷键:http://electronjs.org/docs/api/accelerator