hdu4528 小明系列故事——捉迷藏(记录状态的BFS)题解
思路:
一道BFS题,和以前的BFS有点不同,这里的vis数组需要记录每次走时的状态,所以开了3维,只对该状态下的vis修改。
注意坑点:S的位置是可以走的
代码:
#include<queue>
#include<cstdio>
#define ll long long
using namespace std;
const int N = 100+5;
char mp[N][N];
bool vis[4][N][N];
int X1,Y1,X2,Y2,x,y,n,m,t,to[4][2] = {0,1,0,-1,1,0,-1,0},cnt = 1;
struct node{
int x,y;
int step;
int Find;
};
void update(node &a){
if(a.x == X1 && a.Find != 1){ //等于1不改变状态
int s = min(a.y,Y1) + 1;
int e = max(a.y,Y1) - 1;
int flag = 1;
for(int i = s;i <= e;i++){
if(mp[X1][i] != '.'){
flag = 0;
break;
}
}
if(flag) a.Find = (a.Find == 0? 1 : 3);
}
if(a.x == X2 && a.Find != 2){
int s = min(a.y,Y2) + 1;
int e = max(a.y,Y2) - 1;
int flag = 1;
for(int i = s;i <= e;i++){
if(mp[X2][i] != '.'){
flag = 0;
break;
}
}
if(flag) a.Find = (a.Find == 0? 2 : 3);
}
if(a.y == Y1 && a.Find != 1){
int s = min(a.x,X1) + 1;
int e = max(a.x,X1) - 1;
int flag = 1;
for(int i = s;i <= e;i++){
if(mp[i][Y1] != '.'){
flag = 0;
break;
}
}
if(flag) a.Find = (a.Find == 0? 1 : 3);
}
if(a.y == Y2 && a.Find != 2){
int s = min(a.x,X2) + 1;
int e = max(a.x,X2) - 1;
int flag = 1;
for(int i = s;i <= e;i++){
if(mp[i][Y2] != '.'){
flag = 0;
break;
}
}
if(flag) a.Find = (a.Find == 0? 2 : 3);
}
}
void BFS(){
queue<node> q;
while(!q.empty()) q.pop();
node a,b;
a.x = x,a.y = y,a.Find = 0,a.step = 0;
update(a);
q.push(a);
while(!q.empty()){
a = q.front();q.pop();
if(a.Find == 3 && a.step <= t){
printf("Case %d:\n%d\n",cnt++,a.step);
return;
}
for(int i = 0;i < 4;i++){
b.x = a.x + to[i][0];
b.y = a.y + to[i][1];
if(b.x < 1 || b.y < 1 || b.x > n || b.y > m) continue;
if(mp[b.x][b.y] != '.') continue;
b.Find = a.Find;
update(b);
if(vis[b.Find][b.x][b.y]) continue;
vis[b.Find][b.x][b.y] = true;
b.step = a.step + 1;
q.push(b);
}
}
printf("Case %d:\n-1\n",cnt++);
}
int main(){
int T;
scanf("%d",&T);
while(T--){
scanf("%d%d%d",&n,&m,&t);
for(int i = 1;i <= n;i++){
scanf("%s",mp[i] + 1);
for(int j = 1;j <= m;j++){
if(mp[i][j] == 'D') X1 = i,Y1 = j;
else if(mp[i][j] == 'E') X2 = i,Y2 = j;
else if(mp[i][j] == 'S') x = i,y = j,mp[i][j] = '.';
}
}
memset(vis,0,sizeof(vis));
BFS();
}
return 0;
}
hdu4528 小明系列故事——捉迷藏(记录状态的BFS)题解的更多相关文章
- hdu4528 小明系列故事——捉迷藏
Time Limit: 500/200 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) Total Submission(s ...
- HDU-4528 小明系列故事——捉迷藏 BFS模拟
题意:链接 分析:每一个D或者是E点往四面延伸,并且赋一个特殊的值,能看到D点的点赋值为1,能看到E点的点赋值为1000,这是因为最多100步,因此最后可以根据除以1000和对1000取模来得出某个状 ...
- C - 小明系列故事――捉迷藏 HDU - 4528 bfs +状压 旅游-- 最短路+状压
C - 小明系列故事――捉迷藏 HDU - 4528 这个题目看了一下题解,感觉没有很难,应该是可以自己敲出来的,感觉自己好蠢... 这个是一个bfs 用bfs就很好写了,首先可以预处理出大明和二明能 ...
- HDU 4528 BFS 小明系列故事——捉迷藏
原题直通车:HDU 4528 小明系列故事——捉迷藏 分析: 标记时加两种状态就行. 代码: #include<iostream> #include<cstring> #inc ...
- HDU 4828 小明系列故事——捉迷藏
漂亮妹子点击就送:http://acm.hdu.edu.cn/showproblem.php?pid=4528 Time Limit: 500/200 MS (Java/Others) Memo ...
- HDU 4528 小明系列故事――捉迷藏
广搜. 根据题意,可以知道状态总共有$4*n*m$种.每一个位置四种状态:两个都没有发现:发现$E$没发现$D$:发现$D$没发现$E$:两个都发现. 每次移动的花费都是$1$,队列里面状态的费用是单 ...
- HDU 4511 小明系列故事——女友的考验 (AC自动机+DP)
小明系列故事——女友的考验 Time Limit: 500/200 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Total ...
- HDU 4511 小明系列故事——女友的考验 (AC自动机 + DP)
小明系列故事——女友的考验 Time Limit: 500/200 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Total ...
- hdu 4506 小明系列故事——师兄帮帮忙【幂取模乱搞】
链接: http://acm.hdu.edu.cn/showproblem.php?pid=4506 http://acm.hust.edu.cn/vjudge/contest/view.action ...
随机推荐
- Unity优化----drawcall系列
本文由博主(国宝大熊猫)原创,转载请注明出处:http://www.cnblogs.com/xsln/p/5151951.html 知识普及: *Drawcall影响的是CPU的效率.因为d ...
- 【Loadrunner】【浙江移动项目手写代码】代码备份
vuser_init(){ lr_start_transaction("login"); web_url("10.78.224.136:8080" ...
- json数据处理:读取文件中的json字符串,转为python字典
方法1: 读取文件中的json字符串, 再用json.loads转为python字典 import json str_file = './960x540/config.json' with open( ...
- python len() 函数
Python len() Python len() 方法返回对象(字符.列表.元组等)长度或项目个数. len(obj) 方法语法 obj -- 对象(字符串.列表.元组.字典等) 字符串长度 > ...
- python 面向对象 issubclass
判断是否 他的父类 class Foo(object): pass obj = Foo() class Boo(Foo): pass class Coo(Boo): pass obj = Boo() ...
- 【Mysql优化三章】第一章
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/Bv5f4b8Peex/article/details/78130845 如今网上的好多mysql优化 ...
- #if的使用说明
#if的后面接的是表达式 #if (MAX==10)||(MAX==20) code... #endif 它的作用是:如果(MAX==10)||(MAX==20)成立,那么编译器就会把其中的#if 与 ...
- Unity 脚本的执行顺序
在Unity脚本中常用到的函数就是下面这些,他们的顺序也是按照箭头的方向执行的. Awake ->OnEable-> Start -> FixedUpdate-> Update ...
- 给JSON中put的value=null时,这对key=value会被隐藏掉。
当我们在JSON里像这样json.put("key",null);put值进去的话,这个键值对就会被隐藏掉例如下面的例子: <pre name="code" ...
- 使用JDBC+POI把Excel中的数据导出到MySQL
POI是Apache的一套读MS文档的API,用它还是可以比较方便的读取Office文档的.目前支持Word,Excel,PowerPoint生成的文档,还有Visio和Publisher的. htt ...