hdu 1429 胜利大逃亡(续)(bfs+状态压缩)
Ignatius再次被魔王抓走了(搞不懂他咋这么讨魔王喜欢)…… 这次魔王汲取了上次的教训,把Ignatius关在一个n*m的地牢里,并在地牢的某些地方安装了带锁的门,钥匙藏在地牢另外的某些地方。刚开始Ignatius被关在(sx,sy)的位置,离开地牢的门在(ex,ey)的位置。Ignatius每分钟只能从一个坐标走到相邻四个坐标中的其中一个。魔王每t分钟回地牢视察一次,若发现Ignatius不在原位置便把他拎回去。经过若干次的尝试,Ignatius已画出整个地牢的地图。现在请你帮他计算能否再次成功逃亡。只要在魔王下次视察之前走到出口就算离开地牢,如果魔王回来的时候刚好走到出口或还未到出口都算逃亡失败。
每组测试数据的第一行有三个整数n,m,t(<=n,m<=,t>)。接下来的n行m列为地牢的地图,其中包括: . 代表路
* 代表墙
@ 代表Ignatius的起始位置
^ 代表地牢的出口
A-J 代表带锁的门,对应的钥匙分别为a-j
a-j 代表钥匙,对应的门分别为A-J 每组测试数据之间有一个空行。
针对每组测试数据,如果可以成功逃亡,请输出需要多少分钟才能离开,如果不能则输出-。
@A.B.
a*.*.
*..*^
c..b* @A.B.
a*.*.
*..*^
c..b*
-
第46行,if((t2.key&(1<<j))==0){//写成 t2.key&(1<<j)==0竟然一直错,&#%**&*!@#@#@!@!
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#include<stdlib.h>
#include<algorithm>
using namespace std;
#define N 26
#define M (1<<10)+6
int n,m,t;
char mp[N][N];
struct Node{
int x,y;
int t;
int key;
}st,ed;
int dirx[]={,,-,};
int diry[]={-,,,};
char keys[]={'a','b','c','d','e','f','g','h','i','j'};
char door[]={'A','B','C','D','E','F','G','H','I','J'};
int vis[N][N][M];
void bfs(){
queue<Node>q;
q.push(st);
vis[st.x][st.y][st.key]=;
Node t1,t2;
while(!q.empty()){
t1=q.front();
//printf("*** %d%d %d\n",t1.x,t1.y,t1.key);
q.pop();
if(t1.x==ed.x && t1.y==ed.y && t1.t<t){
printf("%d\n",t1.t);
return;
}
for(int i=;i<;i++){
t2=t1;
t2.x=t1.x+dirx[i];
t2.y=t1.y+diry[i];
if(mp[t2.x][t2.y]=='*') continue;
if(t2.x< || t2.x>=n || t2.y< || t2.y>=m) continue;
if(vis[t2.x][t2.y][t2.key]) continue;
if(islower(mp[t2.x][t2.y])){
for(int j=;j<;j++){
if(mp[t2.x][t2.y]==keys[j]){ if((t2.key&(<<j))==){//写成 t2.key&(1<<j)==0竟然一直错,&#%**&*!@#@#@!@!
t2.key+=(<<j);
t2.t++;
vis[t2.x][t2.y][t2.key]=;
q.push(t2);
}
else{
//printf("+++%d\n",t2.key);
if(vis[t2.x][t2.y][t2.key]==){
t2.t++;
vis[t2.x][t2.y][t2.key]=;
q.push(t2);
}
}
}
}
}
else if(isupper(mp[t2.x][t2.y])){
for(int j=;j<;j++){
if(mp[t2.x][t2.y]==door[j]){
if(t2.key&(<<j)){
t2.t++;
vis[t2.x][t2.y][t2.key]=;
q.push(t2);
}
}
}
}
else{
t2.t++;
vis[t2.x][t2.y][t2.key]=;
q.push(t2);
} }
}
printf("-1\n");
}
int main()
{
while(scanf("%d%d%d",&n,&m,&t)==){
for(int i=;i<n;i++){
scanf("%s",mp[i]);
for(int j=;j<m;j++){
if(mp[i][j]=='@'){
st.x=i;
st.y=j;
st.t=;
st.key=;
}
if(mp[i][j]=='^'){
ed.x=i;
ed.y=j;
}
}
} memset(vis,,sizeof(vis));
bfs();
}
return ;
}
hdu 1429 胜利大逃亡(续)(bfs+状态压缩)的更多相关文章
- 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 ...
- HDOJ 1429 胜利大逃亡(续) (bfs+状态压缩)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1429 思路分析:题目要求找出最短的逃亡路径,但是与一般的问题不同,该问题增加了门与钥匙约束条件: 考虑 ...
- hdu.1429.胜利大逃亡(续)(bfs + 0101011110)
胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ...
- 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再次被魔王抓走了(搞不懂他咋这么讨魔王 ...
- HDU 1429 胜利大逃亡(续)(DP + 状态压缩)
胜利大逃亡(续) Problem Description Ignatius再次被魔王抓走了(搞不懂他咋这么讨魔王喜欢)…… 这次魔王汲取了上次的教训,把Ignatius关在一个n*m的地牢里,并在地牢 ...
- HDU 1429 胜利大逃亡(续)(bfs)
胜利大逃亡(续) 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 ...
随机推荐
- [转]notifyDataSetChanged() 动态更新ListView
有时候我们需要修改已经生成的列表,添加或者修改数据,notifyDataSetChanged()可以在修改适配器绑定的数组后,不用重新刷新Activity,通知Activity更新ListView.今 ...
- C++中的重载、覆盖、隐藏
前几天面试时被问及C++中的覆盖.隐藏,概念基本答不上来,只答了怎么用指针实现多态,也还有遗漏.最终不欢而散.回来后在网上查找学习了一番,做了这个总结.其中部分文字借用了别人的博客,望不要见怪.引用的 ...
- 自己实现一个SQL解析引擎
自己实现一个SQL解析引擎 功能:将用户输入的SQL语句序列转换为一个可运行的操作序列,并返回查询的结果集. SQL的解析引擎包含查询编译与查询优化和查询的执行,主要包含3个步骤: 查询分析: 制定逻 ...
- Python一日一练05----怒刷点击量
功能 自己主动获取CSDN文章列表,并对每篇文章添加点击量. 源代码 import urllib.request import re import time import random from bs ...
- JMeter简单性能测试(适合初学者)
利用JMeter进行Web测试 JMeter介绍 脚本录制 运行JMeter进行测试 JMeter主要组件介绍 参数化设置 动态数据关联 使用命令行运行JM ...
- AAM(Active Appearance Model)算法介绍
前面介绍ASM算法(http://blog.csdn.net/carson2005/article/details/8194317)的时候,笔者提到,ASM是基于统计形状模型的基础上进行的,而AAM则 ...
- c++11: trailing return type in functions(函数返回类型后置)
In C++03, the return type of a function template cannot be generalized if the return type relies on ...
- 正确的安装qwtplot3D开发库
1.从网上下载qwtplot3D的最新版本:http://qwtplot3d.sourceforge.net/ 2.解压qwtplot3d-0.2.7.zip到C盘根目录下(注意:路径中不能带有中文汉 ...
- C++设计模式---Strategy模式
一.前言 学习的第一个设计模式!不知道理解的对不对,期望大家一起多交流~ Strategy模式:策略模式,定义了算法族,分别封装起来,此模式可以让算法的变化独立于使用算法的客户.Strategy模式将 ...
- C#基础之方法参数
params params 关键字可以指定在参数数目可变处采用参数的方法参数. 在方法声明中的 params 关键字之后不允许任何其他参数,并且在方法声明中只允许一个 params 关键字 publi ...