题意:

n*m的迷宫。多多要从(1,1)到达(n,m)。每移动一步消耗1秒。有P种钥匙。

有K个门或墙。给出K个信息:x1,y1,x2,y2,gi    含义是(x1,y1)与(x2,y2)之间有gi。gi=0:墙   1,2,3.... :第1种门,第2种门,第3种门.....

有S把钥匙。给出S个信息:x1,y1,qi    含义是位置(x1,y1)上有一把第qi种的钥匙。

问多多最少花多少秒到达(n,m)。若无法到达输出-1。

数据范围:

(1<= n, m <=50, 0<= p <=10).

(0<= k <=500)

(0<= S <=50)

思路:

n,m很小。经典BFS+状压,

注意的是,同一位置上可能有多把钥匙。(注意到S的范围是S<=50)

还有一个要注意:位运算式子的处理要仔细。(最好测试一下)。

代码:

struct node{
int x,s;
node(int _x,int _s){
x=_x, s=_s;
}
}; int n,m,p,k,S;
int xx1,yy1,xx2,yy2,gi;
int mazeG[55][55][55][55], mazeK[55][55][15];
int dp[55][55][1050]; int bfs(){
queue<node> q;
mem(dp,-1);
int s=0;
rep(i,1,p) if(mazeK[1][1][i]>0) s|=(1<<(i-1));
q.push(node(101,s));
dp[1][1][s]=0;
if(1==n && 1==m) return 0;
while(!q.empty()){
node f=q.front(); q.pop();
rep(i,0,3){
int nx=f.x/100+uu[i], ny=f.x%100+vv[i];
int _s=f.s;
if(nx<=0||ny<=0||nx>n||ny>m||(mazeG[f.x/100][f.x%100][nx][ny]==0)) continue; //overBound or meet the wall. if(mazeG[f.x/100][f.x%100][nx][ny]>0){
int yes=_s&(1<<(mazeG[f.x/100][f.x%100][nx][ny]-1));
if(yes==0) continue; //don't have corresponding key.
}
int ns=_s;
rep(i,1,p) if(mazeK[nx][ny][i]) ns|=(1<<(i-1));
if(dp[nx][ny][ns]!=-1) continue;
q.push(node(nx*100+ny,ns));
dp[nx][ny][ns]=dp[f.x/100][f.x%100][_s]+1;
if(nx==n&&ny==m) return dp[nx][ny][ns];
}
}
return -1;
} int main(){
while(scanf("%d%d%d",&n,&m,&p)!=EOF){ //p kinds of doors
scanf("%d",&k);
mem(mazeG,-1); //doors or walls
mem(mazeK,false); //keys
rep(i,1,k){
scanf("%d%d%d%d%d",&xx1,&yy1,&xx2,&yy2,&gi);
mazeG[xx1][yy1][xx2][yy2]=gi;
mazeG[xx2][yy2][xx1][yy1]=gi;
}
scanf("%d",&S); // S keys
rep(i,1,S){
scanf("%d%d%d",&xx1,&yy1,&gi);
mazeK[xx1][yy1][gi]=true;
}
printf("%d\n",bfs());
}
}

hdu 5094 Maze (BFS+状压)的更多相关文章

  1. HDU 5094 Maze (状压)

    加一个维度,钥匙的状态,状压一下.n很小,钥匙也只有10个,bfs就好了. 忘了数组初始化.以后坚决不犯这种低级错误. #include<cstdio> #include<queue ...

  2. HDU - 5094 Maze(状压+bfs)

    Maze This story happened on the background of Star Trek. Spock, the deputy captain of Starship Enter ...

  3. hdu 4856 Tunnels (bfs + 状压dp)

    题目链接 The input contains mutiple testcases. Please process till EOF.For each testcase, the first line ...

  4. HDU 5094 题解(状压BFS)

    题面: Maze 题目中文大意: 这个故事发生在“星际迷航”的背景下. “星际争霸”的副队长史波克落入克林贡的诡计中,被关押在他们的母亲星球Qo’noS上. 企业的上尉詹姆斯·T·柯克(James T ...

  5. hdu 5094 Maze bfs

    传送门:上海邀请赛E 给定一个n×m的迷宫,给出相邻格子之间的墙或者门的信息,墙说明不可走,假设是门则须要有相应的钥匙才干通过,问是否可以从(1,1)到达(n,m) 一个带状态的bfs,再另记一个状态 ...

  6. hdu 3247 AC自动+状压dp+bfs处理

    Resource Archiver Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 100000/100000 K (Java/Ot ...

  7. hdu 4771 Stealing Harry Potter's Precious (BFS+状压)

    题意: n*m的迷宫,有一些格能走("."),有一些格不能走("#").起始点为"@". 有K个物体.(K<=4),每个物体都是放在& ...

  8. hdu 5094 Maze 状态压缩dp+广搜

    作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4092176.html 题目链接:hdu 5094 Maze 状态压缩dp+广搜 使用广度优先 ...

  9. hdu 2825 aC自动机+状压dp

    Wireless Password Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

随机推荐

  1. 每日学习——C++习题

    1.题目要求:求圆的面积,数据成员为半径r,定义为私有成员,要求用成员函数实现在键盘上输入圆半径,计算圆面积.输出圆面积三个功能,要求三个成员函数在类内声明,在类外定义 //定义类 class Cir ...

  2. 消息队列之 kafka 集群搭建

    我们先弄清楚kafka集群环境首先需要些什么 JDK 10+ Zookeeper Kafka 2.x 首先准备三台虚拟机 centos7 ,更改IP地址为静态地址分别为,29.30.31 cd /et ...

  3. ATR吊灯止损策略 (含有tbquant源码)

    ATR吊灯止损策略定义: 做多,止损放在最高价之下N个ATR. 做空,止损放在最低价之上N个ATR. 该策略生成的止损点就像是从市场最高价的"天花板"上悬挂下来的吊灯.所以命名为A ...

  4. Java基础系列(19)- Switch结构

    package struct; public class SwitchDemo01 { //case穿透 //switch 匹配一个具体的值 public static void main(Strin ...

  5. 接口管理工具swagger

    swagger,一款致力于解决接口规范化.标准化.文档化的开源库,一款真正的开发神器. swagger三大部分 Editor https://swagger.io/tools/swagger-edit ...

  6. django ORM教程(转载)

    Django中ORM介绍和字段及字段参数   Object Relational Mapping(ORM) ORM介绍 ORM概念 对象关系映射(Object Relational Mapping,简 ...

  7. 详细的vsftpd配置

    环境:CentOS 5.0 操作系统一.安装:1.安装Vsftpd服务相关部件:[root@KcentOS5 ~]# yum install vsftpd*Dependencies Resolved= ...

  8. 鸿蒙内核源码分析(时间管理篇) | 谁是内核基本时间单位 | 百篇博客分析OpenHarmony源码 | v35.02

    百篇博客系列篇.本篇为: v35.xx 鸿蒙内核源码分析(时间管理篇) | 谁是内核基本时间单位 | 51.c.h .o 本篇说清楚时间概念 读本篇之前建议先读鸿蒙内核源码分析(总目录)其他篇. 时间 ...

  9. pycharm中安装扩展包

    在使用Pycharm编写代码时,如果遇到了所需要的扩展包没有的情况时,可以使用以下方法来添加自己需要的扩展包. 1.点击File->settings 2.选择Project Interprete ...

  10. VS2017离线安装QT插件出错:未能正确加载VSIX包

    问题现象: 问题已解决,忘记截图了 出现原因:可能是自己离线安装,安装版本与不符合当前VS吧.记得当时下载了一个最新的版本.重新卸载当前插件,再装一个合适版本即可 http://download.qt ...