hdu 4634 Swipe Bo bfs+状态压缩
状态压缩记录当前拿到了哪些钥匙, 然后暴力搜索。
搞了好几个小时, 一开始也不知道哪里错了, 最后A了也不知道一开始哪里有问题。
#include <iostream>
#include <vector>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <map>
#include <set>
#include <string>
#include <queue>
#include <stack>
#include <bitset>
using namespace std;
#define pb(x) push_back(x)
#define ll long long
#define mk(x, y) make_pair(x, y)
#define lson l, m, rt<<1
#define mem(a) memset(a, 0, sizeof(a))
#define rson m+1, r, rt<<1|1
#define mem1(a) memset(a, -1, sizeof(a))
#define mem2(a) memset(a, 0x3f, sizeof(a))
#define rep(i, n, a) for(int i = a; i<n; i++)
#define fi first
#define se second
typedef pair<int, int> pll;
const double PI = acos(-1.0);
const double eps = 1e-;
const int mod = 1e9+;
const int inf = ;
const int dir[][] = { {-, }, {, }, {, -}, {, } };
const int maxn = ;
int n, m, cnt, g[maxn][maxn];
bool vis[maxn][maxn][<<][], used[maxn][maxn][<<];
char s[maxn][maxn];
struct node
{
int x, y, step, key;
node(){}
node(int _x, int _y, int _step, int _key): x(_x), y(_y), step(_step), key(_key){}
};
queue <node> q;
int check(int x, int y) {
if(x>=&&x<n&&y>=&&y<m)
return ;
return ;
}
int judge(int x, int y) {
if(x == )
return ;
if(x == -)
return ;
if(y == )
return ;
if(y == -)
return ;
}
void bfs(int x, int y) {
mem(vis);
mem(used);
while(!q.empty())
q.pop();
used[x][y][] = ;
q.push(node(x, y, , ));
while(!q.empty()) {
node temp = q.front(); q.pop();
int x = temp.x, y = temp.y, tmpx, tmpy;
for(int i = ; i < ; i++) {
int dirx = dir[i][], diry = dir[i][];
tmpx = x, tmpy = y;
int key = temp.key;
node tmp = temp;
if(!check(tmpx+dirx, tmpy+diry) || s[tmpx+dirx][tmpy+diry]=='#')
continue;
while() {
if(s[tmpx][tmpy] == 'L')
dirx = , diry = -;
if(s[tmpx][tmpy] == 'R')
dirx = , diry = ;
if(s[tmpx][tmpy] == 'U')
dirx = -, diry = ;
if(s[tmpx][tmpy] == 'D')
dirx = , diry = ;
int tmpdir = judge(dirx, diry);
if(vis[tmpx][tmpy][tmp.key][tmpdir])
break;
vis[tmpx][tmpy][tmp.key][tmpdir] = ;
if(s[tmpx][tmpy] == 'E' && key == (<<cnt)-) {
printf("%d\n", temp.step+);
return ;
}
if(s[tmpx][tmpy] == 'K')
key |= g[tmpx][tmpy];
if(check(tmpx+dirx, tmpy+diry)) {
if(s[tmpx+dirx][tmpy+diry] == '#') {
tmp.x = tmpx;
tmp.y = tmpy;
tmp.step++;
tmp.key = key;
q.push(tmp);
used[tmpx][tmpy][tmp.key] = ;
break;
} else {
tmpx += dirx;
tmpy += diry;
}
} else {
break;
}
}
}
}
puts("-1");
return ;
}
void solve() {
cnt = ;
int x, y;
for(int i = ; i < n; i++) {
for(int j = ; j < m; j++) {
if(s[i][j] == 'S')
x = i, y = j;
if(s[i][j] == 'K') {
g[i][j] = <<cnt;
cnt++;
}
}
}
bfs(x, y);
}
void read() {
for(int i = ; i < n; i++)
scanf("%s", s[i]);
}
int main()
{
while(scanf("%d%d", &n, &m)!=EOF) {
read();
solve();
}
return ;
}
hdu 4634 Swipe Bo bfs+状态压缩的更多相关文章
- HDU 4634 Swipe Bo (2013多校4 1003 搜索)
Swipe Bo Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Su ...
- HDU 1885 Key Task (BFS + 状态压缩)
题意:给定一个n*m的矩阵,里面有门,有钥匙,有出口,问你逃出去的最短路径是多少. 析:这很明显是一个BFS,但是,里面又有其他的东西,所以我们考虑状态压缩,定义三维BFS,最后一维表示拿到钥匙的状态 ...
- hdu 4634 Swipe Bo 搜索
典型的bfs模拟 (广度优先搜索) ,不过有好多细节要注意,比如图中如果是 R# 走到这个R的话就无限往右走了,这样就挂了~肯定到不了出口.还有一种容易造成死循环的,比如 #E## DLLL D. ...
- HDU 4634 Swipe Bo 状态压缩+BFS最短路
将起始点.终点和钥匙统一编号,预处理: 1.起始点到所有钥匙+终点的最短路 2.所有钥匙之间两两的最短路 3.所有钥匙到终点的最短路 将起始点和所有钥匙四方向出发设为起点BFS一遍,求出它到任意点任意 ...
- hdu 4845 : 拯救大兵瑞恩 (bfs+状态压缩)
题目链接 #include<bits/stdc++.h> using namespace std; typedef long long LL; int n,m,p,s,k; ,,,-}; ...
- 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 ...
随机推荐
- radio与checkbox
最近一直在学习Javascript与asp.net MVC4,每天都在跟着书学习.这样总感觉自己看的很抽象,没有点实际的意义.而且,每次看的东西很容易忘记,所以打算在这里记录自己的学习笔记. Java ...
- 观察者模式:猫叫鼠跑人醒(C#)
本着菜鸟先飞的想法,决定把平时遇到的知识点记录下来,一来是加深理解,二来是方便以后自己查阅.当您看到我这篇文章的时候,觉得代码有哪里不足的地方,请多指教,谢谢.(命名不规范是为了加深自己的理解,多多见 ...
- Hadoop数据操作系统YARN全解析
“ Hadoop 2.0引入YARN,大大提高了集群的资源利用率并降低了集群管理成本.其在异构集群中是怎样应用的?Hulu又有哪些成功实践可以分享? 为了能够对集群中的资源进行统一管理和调度,Hado ...
- mongodb高可用集群搭建
集群构架图如下: 集群大致文件结构:(192.168.137.101节点) 先搭建3个副本集 rs1/mongod.conf rs1/start.sh rs2/mongod.conf 后面类似.... ...
- js查找元素
1.className <!DOCTYPE html> <html> <head lang="en"> <meta charset=&qu ...
- 分支-15. 日K蜡烛图
/* * Main.c * 分支-15. 日K蜡烛图 * Created on: 2014年6月18日 * Author: Boomkeeper ****测试通过***** */ #include & ...
- MYSQL 查询缓存
查询缓存: 是指对select 语句的结果进行缓存,当下一次运行同样的select语句时,就可以直接返回数据,跳过解析,执行,优化阶段. 1.查询缓存会跟踪查询涉及的表,如果表发生变化,相关的缓存都会 ...
- Delphi 把一个ICO转换为BMP
// 方法1 var Icon : TIcon; Bitmap : TBitmap; begin Icon := TIcon.Create; Bitmap := TBitmap.Create; Ico ...
- 谈谈ILDasm的功能限制与解除
原文:谈谈ILDasm的功能限制与解除 首先,我在此申明,此文并不是教别人突破限制,我们只是用学习的眼光看问题 大家都知道ILDasm是.NET程序的反编译工具,它是由Microsoft提供的反编译工 ...
- zoj2588 Burning Bridges(无向图的桥)
题目请戳这里 题目大意:给一张无向图,现在要去掉一些边,使图仍然连通,求不能去掉的边. 题目分析:就是求无向图的桥. tarjan算法跑一遍,和无向图割点十分类似,这里要找low[v] > df ...