1、状压bfs

这个状压体现在key上  我i们用把key状压一下  就能记录到一个点时 已经拥有的key的种类

ban[x1][y1][x2][y1]记录两个点之间的状态 是门 还是墙 还是啥都没有

inc[x][y]记录这个点所存储的钥匙  (可能不止一个 所以要用二进制)

vis[x][y][key]  标记当前点 在拥有的钥匙种类为key时是否走过

#include <iostream>
#include <cstdio>
#include <sstream>
#include <cstring>
#include <map>
#include <cctype>
#include <set>
#include <vector>
#include <stack>
#include <queue>
#include <algorithm>
#include <cmath>
#include <bitset>
#define rap(i, a, n) for(int i=a; i<=n; i++)
#define rep(i, a, n) for(int i=a; i<n; i++)
#define lap(i, a, n) for(int i=n; i>=a; i--)
#define lep(i, a, n) for(int i=n; i>a; i--)
#define rd(a) scanf("%d", &a)
#define rlld(a) scanf("%lld", &a)
#define rc(a) scanf("%c", &a)
#define rs(a) scanf("%s", a)
#define pd(a) printf("%d\n", a);
#define plld(a) printf("%lld\n", a);
#define pc(a) printf("%c\n", a);
#define ps(a) printf("%s\n", a);
#define MOD 2018
#define LL long long
#define ULL unsigned long long
#define Pair pair<int, int>
#define mem(a, b) memset(a, b, sizeof(a))
#define _ ios_base::sync_with_stdio(0),cin.tie(0)
//freopen("1.txt", "r", stdin);
using namespace std;
const int maxn = , INF = 0x7fffffff, LL_INF = 0x7fffffffffffffff;
int n, m, p, k, s;
int ban[maxn][maxn][maxn][maxn], inc[maxn][maxn];
int vis[maxn][maxn][ << + ];
int dis[][] = {{, }, {-, }, {, }, {, -}}; struct node
{
int x, y, key, d;
node(int x, int y, int key, int d) : x(x), y(y), key(key), d(d) {}
}; int bfs()
{
queue<node> Q;
mem(vis, );
Q.push(node(, , | inc[][], ));
vis[][][ | inc[][]] = ;
while(!Q.empty())
{
node is = Q.front(); Q.pop();
for(int i = ; i < ; i++)
{
node it(, , , );
it.x = is.x + dis[i][];
it.y = is.y + dis[i][];
if(it.x < || it.x > n || it.y < || it.y > m)
continue;
if(!ban[it.x][it.y][is.x][is.y])
continue;
if(ban[it.x][it.y][is.x][is.y] == - || is.key & ( << (ban[it.x][it.y][is.x][is.y] -))) //如果下一个点与当前点没有墙或门 或者到当前点时已经有了进入下一个点的钥匙
{
if(!inc[it.x][it.y]) it.key = is.key; //如果下一个点没有存储的钥匙 则直接把当前钥匙传递过去
else it.key = is.key | inc[it.x][it.y]; //如果有存储的钥匙 把存储的钥匙加上即可
if(!vis[it.x][it.y][it.key])
{
vis[it.x][it.y][it.key] = ;
it.d = is.d + ;
Q.push(it);
if(it.x == n && it.y == m)
return it.d;
}
}
}
}
return -;
} int main()
{
while(cin >> n >> m >> p >> k)
{
int x1, y1, x2, y2, G, Q;
mem(ban, -);
mem(inc, );
for(int i = ; i <= k; i++)
{
cin >> x1 >> y1 >> x2 >> y2 >> G;
ban[x1][y1][x2][y2] = ban[x2][y2][x1][y1] = G;
}
cin >> s;
for(int i = ; i <= s; i++)
{
cin >> x1 >> y1 >> Q;
inc[x1][y1] |= ( << (Q - ));
}
cout << bfs() << endl; } return ;
}

2、 分层最短路

最短路是好写,但这个建图比较麻烦吧。。

可能说的是一个把。。。emm。。。

参考论文

拯救大兵瑞恩 HDU - 4845(状压bfs || 分层最短路)的更多相关文章

  1. hdu 4845 状压bfs(分层思想)

    拯救大兵瑞恩 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total Subm ...

  2. hdu 5094 状压bfs+深坑

    http://acm.hdu.edu.cn/showproblem.php?pid=5094 给出n*m矩阵 给出k个障碍,两坐标之间存在墙或门,门最多10种,状压可搞 给出s个钥匙位置及编号,相应的 ...

  3. HDU 4012 Paint on a Wall(状压+bfs)

    Paint on a Wall Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65768/65768 K (Java/Others) ...

  4. HDU Stealing Harry Potter's Precious(状压BFS)

    状压BFS 注意在用二维字符数组时,要把空格.换行处理好. #include<stdio.h> #include<algorithm> #include<string.h ...

  5. POJ 1324 Holedox Moving (状压BFS)

    POJ 1324 Holedox Moving (状压BFS) Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 18091 Acc ...

  6. HDU 4778 状压DP

    一看就是状压,由于是类似博弈的游戏.游戏里的两人都是绝对聪明,那么先手的选择是能够确定最终局面的. 实际上是枚举最终局面情况,0代表是被Bob拿走的,1为Alice拿走的,当时Alice拿走且满足变换 ...

  7. P2622 关灯问题II(状压bfs)

    P2622 关灯问题II 题目描述 现有n盏灯,以及m个按钮.每个按钮可以同时控制这n盏灯——按下了第i个按钮,对于所有的灯都有一个效果.按下i按钮对于第j盏灯,是下面3中效果之一:如果a[i][j] ...

  8. 状压BFS

    ​题意:1个机器人找几个垃圾,求出最短路径. 状压BFS,这道题不能用普通BFS二维vis标记数组去标记走过的路径,因为这题是可以往回走的,而且你也不能只记录垃圾的数量就可以了,因为它有可能重复走同一 ...

  9. HDU 4845 拯救大兵瑞恩(分层图状压BFS)

    拯救大兵瑞恩 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others) Total Sub ...

随机推荐

  1. odooERP系统(框架)总结

    1:Odoo 是一个现代化的商业应用套件,使用 AGPL 许可证,并具有客户关系管理(CRM),人力资源,销售,采购,会计,制造,仓库管理,项目管理,以及众多社区模块. 2:它是基于一个模块化,可扩展 ...

  2. jQuery与js例子

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. Artificial Intelligence Computing Conference(2018.09.12)

    时间:2018.09.12地点:北京国际饭店会议中心

  4. excel的宏与VBA入门——代码调试

    直接介绍重点: 常用的操作是导航栏的逐句与断点: 添加断点:调试->切换断点 单步运行:调试->逐句 查看变量的窗口:视图->本地窗口

  5. [Oracle]构筑TDE 环境的例子

    构筑TDE 环境的例子: 测试环境:12.1.0.2 $ cd $ORACLE_HOME/network/admin$ vim sqlnet.ora $ pwd/u01/app/oracle/prod ...

  6. vsftpd虚拟账户配置

    1. 概述 FTP是文件传输协议,在内外网的文件传输中使用广泛. 本篇博客主要介绍FTP服务器的部署和测试. 2. 软件环境部署 查看系统是否安装FTP软件(vsftpd),执行命令:rpm -qa ...

  7. PHP从入门到精通(二)

     PHP从入门到精通 之PHP中的函数 各位开发者朋友大家好,自上次更新PHP的相关知识,得到了大家的广泛支持.PHP的火爆程度不言而喻,函数作为PHP中极为重要的部分,应诸位的支持,博主继续跟进更新 ...

  8. Linux内核及分析 第四周 扒开系统调用的三层皮(上)

    实验过程 选择20号系统调用getpid(取得进程识别码) 在网上查询getpid函数的C语言代码以及其嵌入式汇编语句 C语言代码: #include <stdio.h> #include ...

  9. 猜字游戏java

    一.实践目的 1.掌握基本输入输出. 2.掌握方法定义与调用,理解参数传递方式. 3.掌握数组的声明.定义与初始化,数组的处理. 4.掌握数组作为方法参数和返回值. 二.实践要求 利用方法.数组.基本 ...

  10. 在Eclipse中使用JUnit4进行单元测试(图文教程一)

    在Eclipse中使用JUnit4进行单元测试 单元测试,JUnit4. 这两个有什么关系呢?这就好比(草)单元测试和(割草机).用这个JUnit4工具去辅助我们进行测试.其实不理解这个也没关系,听多 ...