题目链接:http://poj.org/problem?id=2225

这里要注意的是,输入的是坐标x,y,z,那么这个点就是在y行,x列,z层上。

我竟然WA在了结束搜索上了,写成了输出s.step.我要调疯了。

#include <stdio.h>
#include <queue>
#include <string.h> using namespace std; struct Point
{
int x,y,z;
int step;
} points[]; char maps[][][];
bool vis[][][]; ///上下前后左右
int to[][]= {{,,},{-,,},{,,},{,-,},{,,-},{,,}}; int main()
{
char str[];
while(scanf("%s",str)!=EOF)
{
memset(vis,false,sizeof(vis)); int n;
scanf("%d",&n);
for(int i=; i<n; i++)
for(int j=; j<n; j++)
scanf("%s",maps[i][j]); int x1,y1,z1; ///x 行,y列,z层
int x2,y2,z2;
scanf("%d%d%d%d%d%d",&y1,&x1,&z1,&y2,&x2,&z2); char tmp[];
scanf("%s",tmp); queue<Point> Q;
Point s,next;
s.x = x1;
s.y = y1;
s.z = z1;
s.step = ;
Q.push(s);
vis[s.z][s.x][s.y] = true;
int ans = ;
bool flag = false; while(!Q.empty())
{
Point f;
f = Q.front();
Q.pop();
if(f.x==x2&&f.y==y2&&f.z==z2)
{
flag = true;
ans = f.step;
break;
}
for(int i=; i<; i++)
{
next.x = f.x + to[i][];
next.y = f.y + to[i][];
next.z = f.z + to[i][]; if(next.x<||next.x>=n||next.y<||next.y>=n||next.z<||next.z>=n)
continue;
if(vis[next.z][next.x][next.y]||maps[next.z][next.x][next.y]=='X')
continue; next.step = f.step + ;
//printf("%d %d %d ",next.x,next.y,next.z);
//printf("%d\n",next.step);
vis[next.z][next.x][next.y] = true;
Q.push(next);
}
}
if(flag)
printf("%d %d\n",n,ans);
else printf("NO ROUTE\n");
}
return ;
}

Poj(2225),三维BFS的更多相关文章

  1. POJ 2251 三维BFS(基础题)

    Dungeon Master Description You are trapped in a 3D dungeon and need to find the quickest way out! Th ...

  2. POJ 2251 Dungeon Master --- 三维BFS(用BFS求最短路)

    POJ 2251 题目大意: 给出一三维空间的地牢,要求求出由字符'S'到字符'E'的最短路径,移动方向可以是上,下,左,右,前,后,六个方向,每移动一次就耗费一分钟,要求输出最快的走出时间.不同L层 ...

  3. POJ 2049— Finding Nemo(三维BFS)10/200

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/u013497151/article/details/29562915 海底总动员.... 这个题開始 ...

  4. POJ.2251 Dungeon Master (三维BFS)

    POJ.2251 Dungeon Master (三维BFS) 题意分析 你被困在一个3D地牢中且继续寻找最短路径逃生.地牢由立方体单位构成,立方体中不定会充满岩石.向上下前后左右移动一个单位需要一分 ...

  5. hdu 1240:Asteroids!(三维BFS搜索)

    Asteroids! Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total ...

  6. AOJ.866 飞越原野 (三维BFS)

    AOJ.866 飞越原野 (三维BFS) 题意分析 点我挑战题目 相比于普通的BFS,要多一维来记录当前剩余的体力.而且还要额外的一层循环来处理,飞过的路程. 代码总览 #include <io ...

  7. SDUT OJ 1124 飞越原野 (三维BFS练习)

    飞跃原野 nid=24#time" title="C.C++.go.haskell.lua.pascal Time Limit5000ms Memory Limit 65536K ...

  8. HDU 1240——Asteroids!(三维BFS)POJ 2225——Asteroids

    普通的三维广搜,须要注意的是输入:列,行,层 #include<iostream> #include<cstdio> #include<cstring> #incl ...

  9. POJ 2251 Dungeon Master (三维BFS)

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

随机推荐

  1. vue(5)联动+tab页

    来自:https://juejin.im/post/5a0c191f6fb9a04514639419 1.联动 新增 <input v-model="msg" /> & ...

  2. JAVA生成word的几种方法对比

    首先介绍几种java导出word方案 1.Jacob是Java-COM Bridge的缩写,它在Java与微软的COM组件之间构建一座桥梁.使用Jacob自带的DLL动态链接库,并通过JNI的方式实现 ...

  3. DRF-->1 序列化组件的使用和接口设计---get

    定义序列化器(本质就是一个类),一般包括模型类的字段,有自己的字段类型规则.实现了序列化器后,就可以创建序列化对象以及查询集进行序列化操作,通过序列化对象.data来获取数据(不用自己构造字典,再返回 ...

  4. python函数(四)

    一.函数是什么? 函数一词来源于数学,但编程中的「函数」概念,与数学中的函数是有很大不同的,编程中的函数在英文中也有很多不同的叫法.在BASIC中叫做subroutine(子过程或子程序),在Pasc ...

  5. Collections练习之按照字符串长度进行排序

    不多说,直接上干货! 代码需求 想从 [abcde, cba, aa, zzz, cba, nbaa] 变成 [aa, cba, cba, zzz, nbaa, abcde] CollectionsD ...

  6. 解决 eclipse cdt 运行时控制台乱码解决

    1 点击黑色 倒三角 按钮 选择 run configurations 2 2.1 点击new 添加 LANG = en_US 2.2 选择 replace native environment wi ...

  7. JavaScript Date学习实例:获取3分钟前的时间“hhmmss”格式

    上一篇博客分享了Date对象的理论知识,今天正好看到一段相关的代码,可以继续深化,通过实例加强复习Date 题目:获取3分钟前的时间,并且显示格式是hhmmss 以下是看到的代码 var time=n ...

  8. pat1002. A+B for Polynomials (25)

    1002. A+B for Polynomials (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue T ...

  9. [Eclipse]自动注释功能

    1) 新建一个file时,加上一些注释的方法. window->preference->java->code     styple->code     template 当你选 ...

  10. 祝高二学弟学妹AK NOIp2018!!!!!!