一本通之 一堆迷宫 (Dungeon Master&走出迷宫&走迷宫)
一本通在线崩溃.......
、
有图有真相
这是个三维迷宫,其实和二位迷宫差不多,只是方向多加了2个。
但这个题的输入十分恶心,一度被坑的用cin.ignore(),但还是不过...
它的正确输入方式是这样的
while(scanf("%d%d%d",&n,&m,&s))
{
if(n==&&m==&&s==)break;
for(int i=;i<n;i++)
{for(int j=;j<m;j++)
scanf("%s",a[i][j]);
}
for(int i=;i<n;i++)
{for(int j=;j<m;j++)
{for(int k=;k<s;k++)
{if(a[i][j][k]=='S')
{sx=i;sy=j;sz=k;
}
if(a[i][j][k]=='#')
{vis[i][j][k]=;
}
if(a[i][j][k]=='E')
{fx=i;fy=j;fz=k;
}
}
}
}
}
地图是以字符的形式输入的,考虑到字符从下标0开始读入,这个题更加的恶心了....
那就把整个地图的下标从0开始算吧。
但是这个地图十分难画,因为像上面那样读入,第一个下标是层数(z轴),而不是x轴。既然如此,我们让z轴与x轴互换,对结果没有影响。
接下来就是套迷宫题的模板
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
int sx,sy,sz,fx,fy,fz,n,m,s;
int dx[]={,-,,,,},dy[]={,,-,,,},dz[]={,,,,,-};
struct dl{
int x,y,z,ds;
dl(int xx,int yy,int zz,int ds):x(xx),y(yy),z(zz),ds(ds){}
};
bool vis[][][];
char a[][][];
bool hf(int xx,int yy,int zz)
{if(xx<||xx>=n||yy<||yy>=m||zz<||zz>=s)return ;
if(vis[xx][yy][zz])return ;
return ;
}
void bfs()
{queue<dl>q;
vis[sx][sy][sz]=;
q.push(dl(sx,sy,sz,));
/*for(int i=0;i<=n;i++)
{for(int j=0;j<m;j++)
for(int k=0;k<s;k++)
{printf("vis[%d][%d][%d]=%d ",i,j,k,vis[i][j][k]);
}
printf("\n");
}*/
while(!q.empty())
{
dl ex=q.front();
q.pop(); for(int i=;i<;i++)
{int xx=ex.x,yy=ex.y,zz=ex.z;
xx+=dx[i];yy+=dy[i];zz+=dz[i];
if(hf(xx,yy,zz))
{vis[xx][yy][zz]=;
//printf("xx=%d,yy=%d,zz=%d\n",xx,yy,zz);
int an=ex.ds+;
q.push(dl(xx,yy,zz,an));
}
if(xx==fx&&yy==fy&&zz==fz)
{printf("Escaped in %d minute(s).\n",ex.ds);return ;
}
}
}
printf("Trapped!\n");
}
int main()
{
while(scanf("%d%d%d",&n,&m,&s))
{memset(vis,,sizeof(vis));
if(n==&&m==&&s==)break;
for(int i=;i<n;i++)
{for(int j=;j<m;j++)
scanf("%s",a[i][j]);
}
for(int i=;i<n;i++)
{for(int j=;j<m;j++)
{for(int k=;k<s;k++)
{if(a[i][j][k]=='S')
{sx=i;sy=j;sz=k;
}
if(a[i][j][k]=='#')
{vis[i][j][k]=;
}
if(a[i][j][k]=='E')
{fx=i;fy=j;fz=k;
}
}
}
}
bfs();
}
}
至于走出迷宫这个题,完全就是把三维迷宫减少了一个维度,再改一下输入,其余不变
代码如下
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
int sx,sy,sz,fx,fy,fz,n,m,s;
int dx[]={,-,,,},dy[]={,,-,};
struct dl{
int x,y,ds;
dl(int xx,int yy,int ds):x(xx),y(yy),ds(ds){}
};
bool vis[][];
char a[][];
bool hf(int xx,int yy)
{if(xx<||xx>=n||yy<||yy>=m)return ;
if(vis[xx][yy])return ;
return ;
}
void bfs()
{queue<dl>q;
vis[sx][sy]=;
q.push(dl(sx,sy,));
/*for(int i=0;i<=n;i++)
{for(int j=0;j<m;j++)
for(int k=0;k<s;k++)
{printf("vis[%d][%d][%d]=%d ",i,j,k,vis[i][j][k]);
}
printf("\n");
}*/
while(!q.empty())
{
dl ex=q.front();
q.pop(); for(int i=;i<;i++)
{int xx=ex.x,yy=ex.y;
xx+=dx[i];yy+=dy[i];
if(hf(xx,yy))
{vis[xx][yy]=;
//printf("xx=%d,yy=%d,zz=%d\n",xx,yy,zz);
int an=ex.ds+;
q.push(dl(xx,yy,an));
}
if(xx==fx&&yy==fy)
{printf("%d\n",ex.ds);return ;
}
}
}
}
int main()
{
scanf("%d%d%d",&n,&m);
memset(vis,,sizeof(vis));
for(int i=;i<n;i++)
{
scanf("%s",a[i]);
}
for(int i=;i<n;i++)
{for(int j=;j<m;j++)
{
if(a[i][j]=='S')
{sx=i;sy=j;
}
if(a[i][j]=='#')
{vis[i][j]=;
}
if(a[i][j]=='T')
{fx=i;fy=j;
}
}
}
bfs();
}
走迷宫:把上个题的起点改为(0,0),终点改为(n-1,m-1),输出时+1即可
输出时答案加一是因为我们输出的是出队ex.ds,而不是判断合法,加了1后入队的那个ex.ds,所以当前的出队点距离终点还差一步,所以要+1
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
int sx,sy,sz,fx,fy,fz,n,m,s;
int dx[]={,-,,,},dy[]={,,-,};
struct dl{
int x,y,ds;
dl(int xx,int yy,int ds):x(xx),y(yy),ds(ds){}
};
bool vis[][];
char a[][];
bool hf(int xx,int yy)
{if(xx<||xx>=n||yy<||yy>=m)return ;
if(vis[xx][yy])return ;
return ;
}
void bfs()
{queue<dl>q;
vis[sx][sy]=;
q.push(dl(sx,sy,));
/*for(int i=0;i<=n;i++)
{for(int j=0;j<m;j++)
for(int k=0;k<s;k++)
{printf("vis[%d][%d][%d]=%d ",i,j,k,vis[i][j][k]);
}
printf("\n");
}*/
while(!q.empty())
{
dl ex=q.front();
q.pop();
for(int i=;i<;i++)
{int xx=ex.x,yy=ex.y;
xx+=dx[i];yy+=dy[i];
if(hf(xx,yy))
{vis[xx][yy]=;
//printf("xx=%d,yy=%d,zz=%d\n",xx,yy,zz);
int an=ex.ds+;
q.push(dl(xx,yy,an));
}
if(xx==fx&&yy==fy)
{printf("%d\n",ex.ds+);return ;
}
}
}
}
int main()
{
scanf("%d%d%d",&n,&m);
memset(vis,,sizeof(vis));
sx=;sy=;fx=n-;fy=m-;
for(int i=;i<n;i++)
{
scanf("%s",a[i]);
}
for(int i=;i<n;i++)
{for(int j=;j<m;j++)
{
if(a[i][j]=='#')
{vis[i][j]=;
}
}
}
bfs();
}
一本通之 一堆迷宫 (Dungeon Master&走出迷宫&走迷宫)的更多相关文章
- 【译文】走出Java ClassLoader迷宫 Find a way out of the ClassLoader maze
本文是一篇译文.原文:Find a way out of the ClassLoader maze 对于类加载器,普通Java应用开发人员不需要了解太多.但对于系统开发人员,正确理解Java的类加载器 ...
- POJ 2251 Dungeon Master(3D迷宫 bfs)
传送门 Dungeon Master Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 28416 Accepted: 11 ...
- UVa532 Dungeon Master 三维迷宫
学习点: scanf可以自动过滤空行 搜索时要先判断是否越界(L R C),再判断其他条件是否满足 bfs搜索时可以在入口处(push时)判断是否达到目标,也可以在出口处(pop时) #i ...
- 走出MFC子类化的迷宫
走出MFC子类化的迷宫 KEY WORDS:子类化 SUBCLASSWINDOW MFC消息机制 许多Windows程序员都是跳过SDK直接进行RAD开发工具[或VC,我想VC应不属于RAD]的学习 ...
- 搜索4--noi6264:走出迷宫
搜索4--noi6264:走出迷宫 一.心得 可以去看看别人的代码,吸收精华 二.题目 6264:走出迷宫 查看 提交 统计 提问 总时间限制: 1000ms 内存限制: 65536kB 描述 当 ...
- POJ 2251 Dungeon Master【三维BFS模板】
Dungeon Master Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 45743 Accepted: 17256 Desc ...
- 【POJ - 2251】Dungeon Master (bfs+优先队列)
Dungeon Master Descriptions: You are trapped in a 3D dungeon and need to find the quickest way out! ...
- 棋盘问题(DFS)& Dungeon Master (BFS)
1棋盘问题 在一个给定形状的棋盘(形状可能是不规则的)上面摆放棋子,棋子没有区别.要求摆放时任意的两个棋子不能放在棋盘中的同一行或者同一列,请编程求解对于给定形状和大小的棋盘,摆放k个棋子的所有可行的 ...
- POJ 2251 Dungeon Master --- 三维BFS(用BFS求最短路)
POJ 2251 题目大意: 给出一三维空间的地牢,要求求出由字符'S'到字符'E'的最短路径,移动方向可以是上,下,左,右,前,后,六个方向,每移动一次就耗费一分钟,要求输出最快的走出时间.不同L层 ...
随机推荐
- 剑指Offer (汇总)
刷完剑指Offer很久了,前几天想起来去年开通的博客园,正好把刷题笔记整理一下 刷题平台:牛客网 刷题语言:Python **链表(8道)** [剑指Offer 3. 从尾到头打印链表 (链表)](h ...
- 最新版本汉化-PowerDesigner 16.6 汉化并河蟹
更新日志: 2019-03-14 V1.1 1.支持反复多次汉化: 2.修复少许bug. 最新的16.6版本已经在汉化中了,基本上所有的菜单均已汉化完成,部分窗体还没有编译通过. 不过,不影响尝鲜使用 ...
- 搭建QT环境
开始使用QT时,环境配置好了,以后才不会有这方面的麻烦,所以第一步,把自己的工作环境搭建好! 下面是我的环境搭建过程,留个记录,也为了后来者能少走一些弯路. 注:本人的系统是WIN7x64位的,其他系 ...
- ssh操作服务器
# -*- coding: utf-8 -*- """ Created on Wed Mar 20 10:15:16 2019 @author: Kuma 1. ssh连 ...
- Java基础知识——算术操作符、自增自减、关系操作符,你真的了解吗?
三人行,必有我师焉.欢迎大家加我的微信 yh18482155461,或扫描下方二维码,关注我的微信公众号,共同探讨Java相关技术问题. 温故知新 上一节我们讲到了Java中的赋值操作符,用案例的方式 ...
- Unity判断用户联网状态,WiFi/移动网络/无网络
Unity判断用户联网状态 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分享. ...
- Map<String,Integer>acount字符串出现的次数
- PAT乙级考前总结(三)
特殊题型 1027 打印沙漏 (20 分) 题略,感觉有点像大学里考试的题.找规律即可. #include <stdio.h>#include <iostream>using ...
- 2018.8.8 SpringMVC分层
分层: 表示层:请求分发,调用处理器,页面展示. 业务层:业务处理接口和实现. 持久层:数据访问和持久化. 各层之间解耦,下层对上层透明. 具体代码分析如下图,图转自https://blog.csdn ...
- 2018.5.3 docker
# docker [TOC] ## docker概念 概念官网解释:[docker官网](https://www.docker.com/) 1. 开放平台 2. 容器技术 3. LXC(Linux C ...