hdu 4845 : 拯救大兵瑞恩 (bfs+状态压缩)
#include<bits/stdc++.h>
using namespace std;
typedef long long LL; int n,m,p,s,k;
int dx[]={,,,-};
int dy[]={,-,,}; bool vis[][][<<]; //vis[i][j][k]记录是否以k状态访问过(i,j)位置
int wall[][][][]; //记录墙和门的情况
int key[][]; //记录迷宫中钥匙的存在状态 struct node
{
int x,y; //x,y记录坐标
int own; //own记录钥匙的拥有情况
int dis; //dis记录到原点的最短距离
}; bool in(int x,int y)
{
return <=x&&x<=n&&<=y&&y<=m;
} int bfs()
{
vis[][][key[][]]=;
queue<node> q;
q.push((node){,,key[][],});
while(!q.empty())
{
node cur=q.front();
q.pop();
int px=cur.x,py=cur.y,pdis=cur.dis;
for(int i=;i<;i++)
{
int own=cur.own;
int x=px+dx[i];
int y=py+dy[i];
if(!in(x,y)||wall[px][py][x][y]==) continue; //不在边界内或是一堵墙
int door= (wall[px][py][x][y]==-? :wall[px][py][x][y]);
if(!(own&(<<door))) continue; //没有钥匙
if(x==n&&y==m) return pdis+; //到达终点
own|=key[x][y]; //捡到该点的钥匙
if(vis[x][y][own]) continue;
vis[x][y][own]=;
q.push((node){x,y,own,pdis+});
}
}
return -;
} int main()
{
while(cin>>n>>m>>p)
{
memset(wall,-,sizeof(wall));
memset(key,,sizeof(key));
memset(vis,,sizeof(vis));
cin>>k;
while(k--)
{
int x1,y1,x2,y2,g;
cin>>x1>>y1>>x2>>y2>>g;
wall[x1][y1][x2][y2]=wall[x2][y2][x1][y1]=g;
}
cin>>s;
while(s--)
{
int x,y,q;
cin>>x>>y>>q;
key[x][y]|=<<q;
}
key[][]|=; //捡到原点的钥匙
cout<<bfs()<<endl;
}
}
hdu 4845 : 拯救大兵瑞恩 (bfs+状态压缩)的更多相关文章
- HDU 4845 拯救大兵瑞恩(分层图状压BFS)
拯救大兵瑞恩 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) Total Sub ...
- HDU 1885 Key Task (BFS + 状态压缩)
题意:给定一个n*m的矩阵,里面有门,有钥匙,有出口,问你逃出去的最短路径是多少. 析:这很明显是一个BFS,但是,里面又有其他的东西,所以我们考虑状态压缩,定义三维BFS,最后一维表示拿到钥匙的状态 ...
- hdu 4634 Swipe Bo bfs+状态压缩
题目链接 状态压缩记录当前拿到了哪些钥匙, 然后暴力搜索. 搞了好几个小时, 一开始也不知道哪里错了, 最后A了也不知道一开始哪里有问题. #include <iostream> #inc ...
- HDU 3247 Resource Archiver (AC自己主动机 + BFS + 状态压缩DP)
题目链接:Resource Archiver 解析:n个正常的串.m个病毒串,问包括全部正常串(可重叠)且不包括不论什么病毒串的字符串的最小长度为多少. AC自己主动机 + bfs + 状态压缩DP ...
- BFS+状态压缩 hdu-1885-Key Task
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1885 题目意思: 给一个矩阵,给一个起点多个终点,有些点有墙不能通过,有些点的位置有门,需要拿到相应 ...
- ACM/ICPC 之 BFS+状态压缩(POJ1324(ZOJ1361))
求一条蛇到(1,1)的最短路长,题目不简单,状态较多,需要考虑状态压缩,ZOJ的数据似乎比POj弱一些 POJ1324(ZOJ1361)-Holedox Moving 题意:一条已知初始状态的蛇,求其 ...
- HDU1429+bfs+状态压缩
bfs+状态压缩思路:用2进制表示每个钥匙是否已经被找到.. /* bfs+状态压缩 思路:用2进制表示每个钥匙是否已经被找到. */ #include<algorithm> #inclu ...
- hdu 5025 Saving Tang Monk 状态压缩dp+广搜
作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4092939.html 题目链接:hdu 5025 Saving Tang Monk 状态压缩 ...
- poj 1753 Flip Game(bfs状态压缩 或 dfs枚举)
Description Flip game squares. One side of each piece is white and the other one is black and each p ...
随机推荐
- (转)datagridview 自定义列三步走
本文转载自:http://blog.csdn.net/zx13525079024/article/details/4814642 我们如果想自定义实现datagridview的某列,例如是datagr ...
- JS - 创建只读属性
一:为私有变量创建get()方法 这种方式可以创建 "伪 "只读属性.这并不是一种好方法,因为使用_函数_获得只读的_属性_不太符合一般的逻辑. /** * Represent a ...
- python-笔记(四)函数
一.函数是什么? 函数一次来源于数学,但是编程中的[函数]的概念,与数学中的函数还是有很大的不同的,编程中的函数在英文中也有很多不同的叫法. 在Basic中叫做subroutine(子过程或子程序), ...
- 【MongoDB】 windows下建立双机主从
[双机配置] 服务端: 两台 Dell R730 双路E5 服务器 使用一个内网环境,网段20, ping 测试互通 主服ip: 192.168.20.176: 27017 从服ip: 192.168 ...
- docker进阶——数据管理与网络
一.数据卷管理 用户在使用 Docker 的过程中,势必需要查看容器内应用产生的数据,或者 需要将容器内数据进行备份,甚至多个容器之间进行数据共享,这必然会涉及 到容器的数据管理 (1)Data Vo ...
- vue 常用插件,保存
UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 mint-ui- Vue 2的移动UI元素 iview- 基于 Vuejs 的开源 UI ...
- powerdisigner
- 《深入浅出WPF》学习总结之XAML标签语言二
x名称空间 “x名称空间”的这个X是映射XML名称空间时给他取的名字(如果用的是字母y,那他就叫“y名称空间了”),x名称空间里的成员(x.name.x.class)是专门给XAML编译器看的.用来引 ...
- SpringBoot(十) -- Spring Data
一.Spring Data简介 Spring Data 项目的目的是为了简化构建基于 Spring 框架应用的数据访问技术,包括非关系数据库.Map-Reduce 框架.云数据服务等等:另外也包含对关 ...
- Spring MVC-学习笔记(1)认识spring mvc
1.基于XML Schema.Controller接口的spring mvc简单例子 1>创建一个动态Web项目,选择同时创建web.xml文件 2>在WEB-INF/lib中粘贴spri ...