描述You are trapped in a 3D dungeon and need to find the quickest way out! The dungeon is composed of unit cubes which may or may not be filled with rock. It takes one minute to move one unit north, south, east, west, up or down. You cannot move diagonally and the maze is surrounded by solid rock on all sides.

Is an escape possible? If yes, how long will it take?

输入

The input consists of a number of dungeons. Each dungeon description starts with a line containing three integers L, R and C (all limited to 30 in size).
L is the number of levels making up the dungeon.
R and C are the number of rows and columns making up the plan of each level.
Then there will follow L blocks of R lines each containing C characters. Each character describes one cell of the dungeon. A cell full of rock is indicated by a '#' and empty cells are represented by a '.'. Your starting position is indicated by 'S' and the exit by the letter 'E'. There's a single blank line after each level. Input is terminated by three zeroes for L, R and C.

输出

Each maze generates one line of output. If it is possible to reach the exit, print a line of the form

Escaped in x minute(s).

where x is replaced by the shortest time it takes to escape.
If it is not possible to escape, print the line

Trapped!

样例输入

3 4 5
S....
.###.
.##..
###.# #####
#####
##.##
##... #####
#####
#.###
####E 1 3 3
S##
#E#
### 0 0 0

样例输出

Escaped in 11 minute(s).
Trapped!

题目大意:在3d迷宫内某一层的一点起步,中间变换楼层,躲避障碍,最终能否走到终点,如果能,输出最少步数。
#include<iostream>
#include<map>
#include<queue>
#include<cstring>
#include<vector>
using namespace std;
int l,r,c,u_d,el;
int xx[4]={0,0,1,-1},yy[4]={1,-1,0,0};
struct L
{
char M[35][35]; }L[35];
typedef struct Node
{
int x,y,l,step;
} Node;
int BFS(int x,int y,int l0)
{
queue<Node>Q;
Node t,temp;
t.x=x;
t.y=y;
t.l=l0;
t.step=0;
Q.push(t);
while(!Q.empty())
{
t=Q.front();
Q.pop();
if(t.x<0||t.x>=r||t.y<0||t.y>=c||L[t.l].M[t.x][t.y]=='#')
continue;
if(L[t.l].M[t.x][t.y]=='E')return t.step;//找到出口
L[t.l].M[t.x][t.y]='#';
if(t.l<l-1&&L[t.l+1].M[t.x][t.y]!='#')//能够前往迷宫下层
{
temp=t;
temp.l=t.l+1;
temp.step=t.step+1;
Q.push(temp);
}
if(t.l>0&&L[t.l-1].M[t.x][t.y]!='#')//能够前往迷宫上层
{
temp=t;
temp.l=t.l-1;
temp.step=t.step+1;
Q.push(temp);
}
for(int i=0;i<4;i++)//迷宫内左右移动
{
temp=t;
temp.x=t.x+xx[i];
temp.y=t.y+yy[i];
temp.step=t.step+1;
Q.push(temp);
}
}
return -1;
} int main()
{
int x0,y0,l0;
while(cin>>l>>r>>c&&l!=0&&r!=0&&c!=0)
{
for(int i=0;i<l;i++)
{
for(int j=0;j<r;j++)
for(int k=0;k<c;k++)
{
cin>>L[i].M[j][k];
if(L[i].M[j][k]=='S'){x0=j;y0=k;l0=i;}
else if(L[i].M[j][k]=='E'){el=i;}
} }
int t=(BFS(x0,y0,l0));
if(t==-1)cout<<"Trapped!"<<endl;
else cout<<"Escaped in "<<t<<" minute(s)."<<endl;
} return 0;
}

NOI-1253:Dungeon Master(BFS)的更多相关文章

  1. hdu 2251 Dungeon Master bfs

    Dungeon Master Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 17555   Accepted: 6835 D ...

  2. POJ2251 Dungeon Master —— BFS

    题目链接:http://poj.org/problem?id=2251 Dungeon Master Time Limit: 1000MS   Memory Limit: 65536K Total S ...

  3. 1253 Dungeon Master

    题目链接: http://noi.openjudge.cn/ch0205/1253/ http://poj.org/problem?id=2251 总时间限制: 1000ms  内存限制: 65536 ...

  4. Dungeon Master bfs

    time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u POJ 2251 Descriptio ...

  5. poj 2251 Dungeon Master (BFS 三维)

    You are trapped in a 3D dungeon and need to find the quickest way out! The dungeon is composed of un ...

  6. [poj] Dungeon Master bfs

    Description You are trapped in a 3D dungeon and need to find the quickest way out! The dungeon is co ...

  7. poj 2251 Dungeon Master( bfs )

    题目:http://poj.org/problem?id=2251 简单三维 bfs不解释, 1A,     上代码 #include <iostream> #include<cst ...

  8. POJ 2251 Dungeon Master (BFS最短路)

    三维空间里BFS最短路 #include <iostream> #include <cstdio> #include <cstring> #include < ...

  9. POJ2251 Dungeon Master(bfs)

    题目链接. 题目大意: 三维迷宫,搜索从s到e的最小步骤数. 分析: #include <iostream> #include <cstdio> #include <cs ...

  10. POJ 2251 Dungeon Master bfs 难度:0

    http://poj.org/problem?id=2251 bfs,把两维换成三维,但是30*30*30=9e3的空间时间复杂度仍然足以承受 #include <cstdio> #inc ...

随机推荐

  1. (转) IIS隐藏响应头信息

    先安装url-rewrite组件 http://www.iis.net/downloads/microsoft/url-rewrite 修改应用根目录下的Web.config配置文件 <conf ...

  2. 使用Kali破解无线密码

    1.查看网卡信息,是否有wlanX网卡ifconfig 2.启动网卡监听模式 airmon-ng start wlan0 检查下是否处于监听模型:ifconfig查看一下,如果网卡名加上了mon后则成 ...

  3. CANas分析软件,DBC文件解析,CAN报文分析,仿CANoe曲线显示

    2023.01.01:增加对Kvaser的支持参考了CANoe写了下面的软件,主要用途是对报文的回放及曲线的分析. 1.CAN连接,支持周立功CAN.CANFD及PCAN 2.DBC解析与生成文件 打 ...

  4. liunx查看端口使用情况

    netstat -ntlp //查看当前所有tcp端口

  5. .NetCore自定义模板,发布Nuget

    1.创建模板项目框架 2.创建模板文件 在项目文件夹根目录创建.template.config文件夹,在文件夹下创建新的文件:template.json 内容如下 { "$schema&qu ...

  6. http头部meta 作用

    <meta charset="utf-8"> <!-- 设置文档字符编码 --> <meta http-equiv="x-ua-compat ...

  7. git diff如何确定差异所在函数context

    问题 在使用git diff 展示c/c++文件修改内容时,除了显示修改上下文外,输出还贴心的展示了修改所在的函数.尽管这个展示并不总是准确,但是能够做到大部分情况下准确也已经相当不错:是不是git内 ...

  8. notepad++ 编写html代码快捷键切换到浏览器查看

    1.右键chrome属性,查看目标C:\Users\duanx\AppData\Local\Google\Chrome\Application\chrome.exe 2.然后notepad运行,输入如 ...

  9. k8s资源清单

    资源清单就是k8s当中用来定义pod的文件,语法格式遵循yaml语法,在yaml当中可以定义控制器类型,元数据,容器端口号等等等....,也可以针对于清单对pod进行删除等操作. 我们可以用kubec ...

  10. 有关插槽中scope的问题

    暂时不理解