可怜的公主在一次次被魔王掳走一次次被骑士们救回来之后,而今,不幸的她再一次面临生命的考验。魔王已经发出消息说将在T时刻吃掉公主,因为他听信谣言说吃公主的肉也能长生不老。年迈的国王正是心急如焚,告招天下勇士来拯救公主。不过公主早已习以为常,她深信智勇的骑士LJ肯定能将她救出。 
现据密探所报,公主被关在一个两层的迷宫里,迷宫的入口是S(0,0,0),公主的位置用P表示,时空传输机用#表示,墙用*表示,平地用.表示。骑士们一进入时空传输机就会被转到另一层的相对位置,但如果被转到的位置是墙的话,那骑士们就会被撞死。骑士们在一层中只能前后左右移动,每移动一格花1时刻。层间的移动只能通过时空传输机,且不需要任何时间。

Input输入的第一行C表示共有C个测试数据,每个测试数据的前一行有三个整数N,M,T。 N,M迷宫的大小N*M(1 <= N,M <=10)。T如上所意。接下去的前N*M表示迷宫的第一层的布置情况,后N*M表示迷宫第二层的布置情况。Output如果骑士们能够在T时刻能找到公主就输出“YES”,否则输出“NO”。Sample Input

1
5 5 14
S*#*.
.#...
.....
****.
...#. ..*.P
#.*..
***..
...*.
*.#..

Sample Output

YES
  思路:求最快到达步骤用广搜,题目要求的数据量并不大,两层每层最大10×10,暴力搜索即可,再加上vis数组标记已到过的点。注意'#'直接就传走了进入另一层且不消耗时间
,判断下在另一层中与'#'对应的位置是不是墙,是墙就不能通过。代码如下:
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <string.h>
#include <vector>
#include <queue>
#include <cmath>
using namespace std;
int n,m,t;
int sx,sy,sz,ex,ey,ez;
char mp[][][];//数据量小,可以直接设
int td[][]={,,,-,,,-,};//移动数组,方便运算
int vis[][][];//标记数组
bool judge(int x,int y,int z)//判断该点是否合法
{
return x<n&&x>=&&y<m&&y>=&&z<&&z>=;
}
struct node{//存放下标和步数
int x,y,z;
int step;
};
queue<node>q;
int bfs()
{
vis[sz][sx][sy]=;//将第一步设为已来过
node p;//初始化信息
p.x=sx,p.y=sy,p.z=sz;
p.step=;
while(!q.empty())q.pop();//清空队列
q.push(p);
while(!q.empty())
{
p=q.front();q.pop();
if(p.x==ex&&p.y==ey&&p.z==ez)return p.step;//找到公主时返回步数,根据队列先进先出的特征,该步数必为最少步数
for(int i=;i<;i++)//进行移动
{
int nx=p.x+td[i][];
int ny=p.y+td[i][];
if(mp[p.z][nx][ny]!='*'&&vis[p.z][nx][ny]==&&judge(nx,ny,p.z))//移动后位置合法时
{
vis[p.z][nx][ny]=;//更新数组信息
if(mp[p.z][nx][ny]=='#')//如果走到了传送门
{
if(p.z==){//在第0层时
if(mp[][nx][ny]!='*'&&mp[][nx][ny]!='#'&&vis[][nx][ny]==)//注意两层相同的位置不能都是传送门
{
vis[][nx][ny]=;
node pp;
pp.x=nx,pp.y=ny;
pp.z=;
pp.step=p.step+;
q.push(pp);
}
}
else if(p.z==)//在第一层时
{
if(mp[][nx][ny]!='*'&&mp[][nx][ny]!='#'&&vis[][nx][ny]==)
{
vis[][nx][ny]=;
node pp;
pp.x=nx,pp.y=ny;
pp.z=;
pp.step=p.step+;
q.push(pp);
}
}
}
else{
node pp;
pp.x=nx,pp.y=ny;
pp.z=p.z;
pp.step=p.step+;
q.push(pp);
}
}
}
}
return ;
}
int main()
{
int c;
scanf("%d",&c);
while(c--)
{
scanf("%d %d %d",&n,&m,&t);
for(int i=;i<;i++)
{
for(int j=;j<n;j++)
{
for(int k=;k<m;k++)
{
cin>>mp[i][j][k];
if(mp[i][j][k]=='S')sx=j,sy=k,sz=i;
if(mp[i][j][k]=='P')ex=j,ey=k,ez=i;
}
}
}
memset(vis,,sizeof(vis));//初始化标记数组
int f=bfs();
if(f<=t&&f!=)printf("YES\n");
else printf("NO\n");
}
return ;
}
 

poj 2102 A计划的更多相关文章

  1. hdu 2102 A计划

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2102 A计划 Description 可怜的公主在一次次被魔王掳走一次次被骑士们救回来之后,而今,不幸 ...

  2. HDU 2102 A计划(两层地图加时间限制加传送门的bfs)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=2102 A计划 Time Limit: 3000/1000 MS (Java/Others)    Me ...

  3. hdu - 2102 A计划 (简单bfs)

    http://acm.hdu.edu.cn/showproblem.php?pid=2102 题目还是不难,注意起点一定是(0,0,0),然后到达P点时间<=t都可以. 用一个3维字符数组存储图 ...

  4. hdu 2102 A计划(优先队列+dfs)

    改了好久,上午来实验室打出来了,运行就是不对,一直找啊找!还是没找到,最后突然停电了,打好的代码还没保存呢! 刚才来的时候又重新打了一遍!!!结果一个小小的错误wrong了好久!!! 在dfs值返回时 ...

  5. hdoj 2102 A计划

    A计划 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  6. hdu 2102 A计划(双层BFS)(具体解释)

    转载请注明出处:http://blog.csdn.net/u012860063?viewmode=contents 题目链接:http://acm.hdu.edu.cn/showproblem.php ...

  7. HDOJ 2102 A计划(bfs)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2102 思路分析: <1>搜索方法分析:由于需要寻找最短的找到公主的路径,所以采用bfs搜索 ...

  8. HDU 2102 A计划 经典搜索

    A计划 Time Limit : 3000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submissio ...

  9. [HDU 2102] A计划(搜索题,典型dfs or bfs)

    A计划 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

随机推荐

  1. Python使用进程间共享变量来控制两个进程(监听键盘和相机录制)的交互

    我有个简单的应用需求: 1. 该应用随时会监听键盘的输入: 2. 当输入指定键时会控制相机录制的启动和关闭. 监听键盘是一个事件循环,相机录制也是一个循环录制的过程.我试着用 Python 启动两个进 ...

  2. 后缀自动机专题(hihocoder)

    传送门 #1445 : 后缀自动机二·重复旋律5 题意: 给出字符串\(s\),询问字符串\(s\)中有多少不同的子串. 思路: 考虑对\(s\)建后缀自动机,那么\(\sum (len[i]-len ...

  3. 使用BCP从Sybase远程数据库中导出数据

    1.在本机安装Sybase ASE 15,我装的开发版全套,懒得去仔细看需要哪个了 2.在Sybase安装目录里找到ini\sql.ini,在里面添加数据源例如: [MYDS] master=NLWN ...

  4. 201871010110-李华《面向对象程序设计(java)》第四周学习总结

    项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/nwnu-daizh/p ...

  5. 201671030126 赵佳平 实验十四 团队项目评审&课程学习总结

    项目 内容 这个作业属于那个课程 2016级计算机科学与工程学院软件工程(西北师范大学) 这个作业的要求在哪里 实验十四 团队项目评审&课程学习总结 作业学习目标 掌握软件项目评审会流程:反思 ...

  6. destoon聚合搜索页面模板

    最近学习大型站点SEO策略,谈到关于大站需要做聚合页面tags,所以根据destoon系统自己做了一个聚合页面,在此分享给吾爱的朋友,一起学习参考! 模板演示站点:http://zhimo.yuanz ...

  7. 排序算法-归并排序(Java)

    package com.rao.sort; import java.util.Arrays; /** * @author Srao * @className MergeSort * @date 201 ...

  8. Hibernate框架学习2

    集合映射 public class User { // 一个用户,对应的多个地址 private Set<String> address; private List<String&g ...

  9. 自用ftp上传脚本

    #!/bin/sh backupserver=$1 #localdir=ftp_result_tmp username=$3 password=$4 #remodir='./Log/2018-01-2 ...

  10. java注释代码规范

    //收集了一小部分,忘记的时候过来查一下 java--hadoop部分 /** * 此类用来处理DNS原始日志:统计给定域名平均响应时延 * @param Input * @param Output ...