1248:Dungeon Master

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

【输入】
多组测试数据。

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

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

【输出】
最小移动次数。

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

##.##
##…

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

0 0 0
【输出样例】
Escaped in 11 minute(s).
Trapped!

#include <iostream>
#include <queue>
#include <cstring>
using namespace std;
char map[99][99][99];
bool vis[99][99][99];
int cnt;
int dx[6]={0,0,0,0,1,-1};
int dy[6]={1,-1,0,0,0,0};
int dz[6]={0,0,1,-1,0,0};
struct node{
	int x,y,z;
	int step;
}s,f;
queue <node> q;
int a,b,c;
void bfs(int xx,int yy,int zz){
	s.x=xx;
	s.y=yy;
	s.z=zz;
	s.step=0;
	vis[xx][yy][zz]=1;
	q.push(s);
	while(!q.empty()){
		f=q.front();
		for(int i=0;i<6;i++){
			int nx=f.x+dx[i];
			int ny=f.y+dy[i];
			int nz=f.z+dz[i];
			if(nx>=0 && nx<a && ny>=0 && ny<b && nz>=0 &&nz<c && map[nx][ny][nz]!='#' && vis[nx][ny][nz]==0){
				s.x=nx;
				s.z=nz;
				s.y=ny;
				s.step=f.step+1;
				if(map[nx][ny][nz]=='E'){
					if(s.step<cnt) cnt=s.step;
				}
				else{
					vis[nx][ny][nz]=1;
					q.push(s);
				}
			}
		}
		q.pop();
	}
	if(cnt!=99999){
		cout<<"Escaped in "<<cnt<<" minute(s)."<<endl;
	}
	else cout<<"Trapped!"<<endl;
}
int main(){
	int u,h,g;
	while(cin>>a>>b>>c){
		if(a==0 && b==0 && c==0) break;
		memset(map,0,sizeof(map));
		memset(vis,0,sizeof(vis));
		cnt=99999;
		for(int i=0;i<a;i++){
			for(int j=0;j<b;j++){
				for(int p=0;p<c;p++) {
				cin>>map[i][j][p];
				if(map[i][j][p]=='S'){
					u=i;
					h=j;
					g=p;
				}
				}
			}
		}
		bfs(u,h,g);
	}
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值