hdoj 1429 胜利大逃亡(续) 【BFS+状态压缩】
题目: pid=1429">hdoj 1429 胜利大逃亡(续)
同样题目:
题意:中文的,自己看
分析:题目是求最少的逃亡时间。确定用BFS
这个题目的难点在于有几个锁对于几把钥匙。唯一的相应关系,不能用直接的标记法,由于一个图可能须要搜索多次。
细致分析的话会发现。图的搜索次数是和钥匙的出现次数相关,那么我们能够用二进制的0 和 1 来表示第几把钥匙出现过没有。所以我们能够用状态压缩来标记那个钥匙出现过,然后用三维标记,第三维表示出现几个钥匙了的情况下图的点的搜索情况。其它就和简单的一样。
AC代码:
#include <cstdio>
#include<iostream>
#include <queue>
#include <cstring>
using namespace std;
const int N = 25;
char map[N][N];
int vis[N][N][1<<11];
struct Node
{
int x,y,step;
int key;
};
int dx[6]={0,0,1,-1};
int dy[6]={1,-1,0,0};
int m,n,t;
int BFS(Node st,Node en)
{
memset(vis,0,sizeof(vis));
st.step = 0;st.key=0;
queue<Node> q;
q.push(st);
Node tmp1,tmp2;
while(!q.empty())
{
tmp1 = q.front();
q.pop();
if(tmp1.x==en.x && tmp1.y==en.y)
return tmp1.step;
for(int i=0;i<4;i++)
{
tmp2.x=tmp1.x+dx[i];
tmp2.y=tmp1.y+dy[i];
tmp2.step = tmp1.step+1;
tmp2.key = tmp1.key;
if(map[tmp2.x][tmp2.y]>='a' && map[tmp2.x][tmp2.y]<='j')
tmp2.key = tmp2.key|(1<<(map[tmp2.x][tmp2.y]-'a'));
if(map[tmp2.x][tmp2.y]=='*' || tmp2.step>=t)
continue;
if(vis[tmp2.x][tmp2.y][tmp2.key]==0 && tmp2.x>=1 && tmp2.y>=1 && tmp2.x<=m && tmp2.y<=n)
{
vis[tmp2.x][tmp2.y][tmp2.key]=1;
if(map[tmp2.x][tmp2.y]>='A' && map[tmp2.x][tmp2.y]<='J')
{
if(tmp2.key&(1<<map[tmp2.x][tmp2.y]-'A'))
q.push(tmp2);
}
else
q.push(tmp2);
}
}
}
return -1;
}
int main()
{
//freopen("Input.txt","r",stdin);
while(~scanf("%d%d%d",&m,&n,&t))
{
Node st,en;
for(int i=1;i<=m;i++)
{
getchar();
for(int j=1;j<=n;j++){
scanf("%c",&map[i][j]);
if(map[i][j]=='@')
st.x=i,st.y=j;
if(map[i][j]=='^')
en.x=i,en.y=j;
}
}
int ans=BFS(st,en);
if(ans<t)
printf("%d\n",ans);
else
puts("-1");
}
return 0;
}
hdoj 1429 胜利大逃亡(续) 【BFS+状态压缩】的更多相关文章
- HDOJ 1429 胜利大逃亡(续) (bfs+状态压缩)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1429 思路分析:题目要求找出最短的逃亡路径,但是与一般的问题不同,该问题增加了门与钥匙约束条件: 考虑 ...
- hdu - 1429 胜利大逃亡(续) (bfs状态压缩)
http://acm.hdu.edu.cn/showproblem.php?pid=1429 终于开始能够做状态压缩的题了,虽然这只是状态压缩里面一道很简单的题. 状态压缩就是用二进制的思想来表示状态 ...
- hdu 1429 胜利大逃亡(续) (bfs+状态压缩)
又开始刷题了 题意:略过. 分析:主要是确定状态量,除了坐标(x,y)之外,还有一个key状态,就好比手上拿着一串钥匙.状态可以用位运算来表示:key&(x,y)表示判断有没有这扇门的钥匙,k ...
- hdu 1429 胜利大逃亡(续)(bfs+位压缩)
胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Su ...
- hdu.1429.胜利大逃亡(续)(bfs + 0101011110)
胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ...
- 胜利大逃亡(续)(状态压缩bfs)
胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ...
- HDOJ 1429 胜利大逃亡(续)
胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Su ...
- HDU 1429 胜利大逃亡(续)(bfs+状态压缩,很经典)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1429 胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others) ...
- hdu 1429 胜利大逃亡(续)
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1429 胜利大逃亡(续) Description Ignatius再次被魔王抓走了(搞不懂他咋这么讨魔王 ...
随机推荐
- Android开发新手HelloWorld解析
首先看这个 HelloWorld 类. Java代码public class HelloWorld extends Activity { /** Called when the activ ...
- SQL SERVER-安装和卸载
卸载后无法正常安装SQL SERVER 删除了本机的SQL SERVER以后,我发现我本机的SQL SERVER 再也安装不上了,这个一个比较严重的问题,要每天定时备份数据库到指定的地方才能防止数据丢 ...
- Eureka Server添加用户认证
Eureka Server添加用户认证 学习了:http://blog.csdn.net/liuchuanhong1/article/details/54729556 注意:1,需要使用 defaul ...
- fieldset 标签 -- 对表单进行分组
转自:https://xhmaomy-163-com.iteye.com/blog/1066977 fieldset——一个不常用的HTML标签 fieldset 标签 -- 对表单进行分组 在for ...
- Under ubuntu 12.04,install sublime text 2
Sublime Text is an awesome text editor. If you’ve never heard of it, you should check it out right n ...
- ubuntu修改顶栏颜色
title: ubuntu修改顶栏颜色 toc: false date: 2018-09-29 19:14:01 categories: methods tags: Ubuntu 编辑shell主题的 ...
- BZOJ 1283 费用流
思路: 最大费用最大流 i->i+1 连边k 费用0 i->i+m (大于n的时候就连到汇) 连边1 费用a[i] //By SiriusRen #include <queue> ...
- CCS+C6678LE开发记录12:UIA组件的安装
在安装了CCS 6.0版本的IDE和最新版的MCSDK后似乎一切都很完美,但事实并非如此. 当我试图编译SDK附带的image_processing (IPC based) demo时出现如下错误: ...
- lucene简单使用demo
测试结构目录: 1.索引库.分词器 Configuration.java package com.test.www.web.lucene; import java.io.File; import or ...
- pugixml读取unicode编码的xml文件的做法
作者:朱金灿 来源:http://blog.csdn.net/clever101 实际上在多字节编码的情况下,即以记事本打开显示的ANSI编码的,如下图: pugixml是可以直接读取中文字符的,示例 ...