ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Dungeon Master 广度优先搜索算法

2022-01-09 13:04:02  阅读:160  来源: 互联网

标签:Dungeon ch int 搜索算法 Master Y1 ##### X1 Z1


【题目描述】

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

【输入】

多组测试数据。

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

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

【输出】

最小移动次数。

【输入样例】

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

【输出样例】

Escaped in 11 minute(s).
Trapped!

【提示】

对于题目给出数据的含义就是输入l,r,c,分别代表迷宫有l层,每层长宽分别是c,r。对于数据以可以这样移动:

 (1,1,1)->(1,1,2)->(1,1,3)->(1,1,4)->(1,1,5)->(1,2,5)->

 (1,3,5)->(1,3,4)->(1,4,4)->(2,4,4)->(2,4,5)->(3,4,,5)

 共11步就可以到达终点 对于数据二明显不能到达,则输出Trapped!

 算法解析

一道三维的广搜,使用单个字符读入分析储存,之后bfs搜索

代码如下

#include<bits/stdc++.h>
using namespace std;
int dx[6]={1,0,-1,0,0,0};
int dy[6]={0,1,0,-1,0,0};
int dz[6]={0,0,0,0,1,-1};
bool a[50][50][50],bo;
int X1,Y1,Z1,X2,Y2,Z2,l,n,m;

struct node
{
	int x,y,z,d;
}h[4100000];

void bfs()
{
	int head=0,tail=1;
	h[1].x=X1;
	h[1].y=Y1;
	h[1].z=Z1;
	h[1].d=0;
	a[X1][Y1][Z1]=1;
	do
	{
		head++;
		for(int i=0;i<6;i++)
		{
			int x=h[head].x+dx[i];
			int y=h[head].y+dy[i];
			int z=h[head].z+dz[i];
			int d=h[head].d+1;
			if(!a[z][x][y]&&x>0&&x<=n&&y>0&&y<=m&&z>0&&z<=l)
			{
				tail++;
				h[tail].x=x;
				h[tail].y=y;
				h[tail].z=z;
				h[tail].d=d;
				a[z][x][y]=1; 
				if(x==X2&&y==Y2&&z==Z2)
				{
					cout<<"Escaped in "<<d<<" minute(s)."<<endl;
					bo=1;
					return;
				}
			}
		}
	}
	while(head<tail);
}

int main()
{
	while(cin>>l>>n>>m)
	{
		if(l==0)
			return 0;
		memset(a,0,sizeof(a));
		for(int i=1;i<=l;i++)
			for(int j=1;j<=n;j++)
				for(int k=1;k<=m;k++)
				{
					char ch;
					cin>>ch;
					if(ch=='#')
						a[i][j][k]=1;
					if(ch=='S')
					{
						X1=j;
						Y1=k;
						Z1=i;
					}
					if(ch=='E')
					{
						X2=j;
						Y2=k;
						Z2=i;
					}
				}
		bo=0;
		bfs();
		if(!bo)
			cout<<"Trapped!"<<endl;
	}
	return 0;
}

标签:Dungeon,ch,int,搜索算法,Master,Y1,#####,X1,Z1
来源: https://blog.csdn.net/whd_wanghaoda/article/details/122392357

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有