信息学奥赛一本通 1248:Dungeon Master(evd)

信息学奥赛题解,介绍了一个三维迷宫问题,要求从起点'S'到终点'E'的最短路径,可以通过上、下、左、右、前、后六个方向移动。解题方法类似二维情况,使用BFS(广度优先搜索)策略,每次移动耗费一分钟。给出多组测试数据和AC代码。
摘要由CSDN通过智能技术生成

【题目描述】
这题是一个三维的迷宫题目,其中用‘.’表示空地,‘#’表示障碍物,‘S’表示起点,‘E’表示终点,求从起点到终点的最小移动次数,解法和二维的类似,只是在行动时除了东南西北移动外还多了上下。可以上下左右前后移动,每次都只能移到相邻的空位,每次需要花费一分钟,求从起点到终点最少要多久。

【输入】
多组测试数据。

一组测试测试数据表示一个三维迷宫:

前三个数,分别表示层数、一个面的长和宽,后面是每层的平面图。前三个数据为三个零表示结束。

【输出】
最小移动次数。

【输入样例】
3 4 5
S…
.###.
.##…
###.#

##.##
##…

#.###
####E
1 3 3
S##
#E#

0 0 0
【输出样例】
Escaped in 11 minute(s).
Trapped!
【心得】如题所述,二维变成三维,每次多了两个决策而已!
【AC代码】

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
using namespace std;
const int N=105;
char a[N][N][N];
int vis[N][N][N],q[N*N*N][3];
int dir[6][3]={
   {
   -1,0,0},{
   1,0,0},{
   0,-1,
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值