NYOJ--353--bfs+优先队列--3D dungeon
/*
Name: NYOJ--3533D dungeon
Author: shen_渊
Date: 15/04/17 15:10
Description: bfs()+优先队列,队列也能做,需要开一个vis[35][35][35]标记
*/
#include<iostream>
#include<queue>
using namespace std;
struct node{
int x,y,z,steps;
node():steps(){
};
bool operator <(const node &a)const {
return steps>a.steps;
}
};
int bfs();
priority_queue<node> q;
int l,r,c;
node s,e;
][][];
] = {{,,},{-,,},{,,},{,-,},{,,},{,,-}};
int main()
{
// freopen("in.txt","r",stdin);
while(cin>>l>>r>>c,l+r+c){
; i<l; ++i){
; j<r; ++j){
cin>>map[i][j];
; k<c; ++k){
if(map[i][j][k] == 'S')s.x = j,s.z = i,s.y = k;
if(map[i][j][k] == 'E')e.x = j,e.y = k,e.z = i;
}
}
}
int t;
if (t=bfs())
cout << "Escaped in " << t << " minute(s)." << endl;
else
cout << "Trapped!" << endl;
}
;
}
int bfs(){
while(!q.empty()) q.pop();
q.push(s);
while(!q.empty()){
node temp = q.top();q.pop();
; i<; ++i){
node a = temp;
a.z += dir[i][];
a.x += dir[i][];
a.y += dir[i][];
a.steps++;
if(a.z == e.z&& a.x==e.x&&a.y==e.y)return a.steps;
if(map[a.z][a.x][a.y] == '#')continue;
|| a.z>=l)continue;
|| a.x>=r)continue;
|| a.y>=c)continue;
q.push(a);
map[a.z][a.x][a.y] = '#';
}
}
;
}
NYOJ--353--bfs+优先队列--3D dungeon的更多相关文章
- nyoj 353 3D dungeon
3D dungeon 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 You are trapped in a 3D dungeon and need to find ...
- NYOJ353 3D dungeon 【BFS】
3D dungeon 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描写叙述 You are trapped in a 3D dungeon and need to find ...
- 3D dungeon
算法:广搜: 描述 You are trapped in a 3D dungeon and need to find the quickest way out! The dungeon is comp ...
- POJ 1724 ROADS(BFS+优先队列)
题目链接 题意 : 求从1城市到n城市的最短路.但是每条路有两个属性,一个是路长,一个是花费.要求在花费为K内,找到最短路. 思路 :这个题好像有很多种做法,我用了BFS+优先队列.崔老师真是千年不变 ...
- hdu 1242 找到朋友最短的时间 (BFS+优先队列)
找到朋友的最短时间 Sample Input7 8#.#####. //#不能走 a起点 x守卫 r朋友#.a#..r. //r可能不止一个#..#x.....#..#.##...##...#.... ...
- HDU 1428 漫步校园 (BFS+优先队列+记忆化搜索)
题目地址:HDU 1428 先用BFS+优先队列求出全部点到机房的最短距离.然后用记忆化搜索去搜. 代码例如以下: #include <iostream> #include <str ...
- hdu1839(二分+优先队列,bfs+优先队列与spfa的区别)
题意:有n个点,标号为点1到点n,每条路有两个属性,一个是经过经过这条路要的时间,一个是这条可以承受的容量.现在给出n个点,m条边,时间t:需要求在时间t的范围内,从点1到点n可以承受的最大容量... ...
- BFS+优先队列+状态压缩DP+TSP
http://acm.hdu.edu.cn/showproblem.php?pid=4568 Hunter Time Limit: 2000/1000 MS (Java/Others) Memo ...
- POJ - 2312 Battle City BFS+优先队列
Battle City Many of us had played the game "Battle city" in our childhood, and some people ...
随机推荐
- C#中的Dictionary的使用
在工作中有时候会用到Dictionary,由于自己之前没用过,参考了一下前人和先辈的实践,仿照着写了一个Test,第一次用还不是很熟练,要多实践练习才能用的得心应手,写代码重在敲键盘,以此为诫.(主要 ...
- 保存Druid的监控记录
继上篇帖子之后 , 公司又要求将Druid Monitor的监控信息保存起来 , 因为Druid的监控记录在是缓存的,重启之后无法找回,所以需要做持久化,定期把监控记录转存到日志文件中 研究了半天 , ...
- linux下修改Apache配置文件
linux下修改host文件host文件存放路径 /etc/hosts 可以用vim编辑 //Apache配置虚拟主机 /usr/local/apache/conf/extra/httpd-vhost ...
- PHP数组按引用传递
<?php /**PHP数组按引用传递**/ $arr = array( array('id' => 1, 'name' => 'name1'), array('id' => ...
- form表单的ajax验证2
form表单的ajax验证2: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"&g ...
- VMware中Mac OS中显示共享文件夹的方法
在finder 偏好设置里的通用标签下,勾选 “已连接的服务器”
- winform控件闪烁问题终极办法
protected override CreateParams CreateParams { get { CreateParams cp = base.CreateParams; cp.ExStyle ...
- href="#" 的坑
第一次发博客, 也不讲究样式. 只是单纯的说一下踩过的坑,方便后人避坑吧 之前做项目的时候,碰到一个非常奇葩的问题. 就是在jqgrid中写了了一个简单的方法 {name:'已经存在的列名称', la ...
- 三、使用vscode在docker中debug
上篇博文中分享了如何用docker-compose搭建AspNetCore的开发环境,在开发过程中debug是必不可少的,如果你使用VS2017的话,右键就可以了,而作为跨平台的.net core开发 ...
- 1. MongoDB 安装和启动
1. MongoDB是一个Document Database.A record in MongoDB is a document,MongoDB documents are similar to JS ...