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 ...
随机推荐
- router-link params传参
1.router.js配置 需要在路径后定义上要传的属性名 --> /:属性名(query方式不需要) { path: '/CreateProgress/:name1', name: ...
- android动态设置边框颜色
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http: ...
- 12 jmeter性能测试实战--web程序
项目背景 项目:XX网站环境:Windows需求:并发登录的性能测试场景:1s增加2个线程,运行2000次(线程数20,Ramp-Up seconds 10,循环次数100).分别看20.40.60并 ...
- golang语言调试
https://software.intel.com/en-us/blogs/2014/05/10/debugging-performance-issues-in-go-programs https: ...
- SVN出现xcrun: error: invalid active developer path(Mac)
Mac升级了系统,配置PHPStorm的SVN,出现如下错误: 具体提示的内容是:xcrun: error: invalid active developer path (/Library/Devel ...
- Mac下PHP7.1+Nginx安装和配置
https://blog.csdn.net/haiyanggeng/article/details/79186982 PHP:7.1.13Nginx:1.12.2 1. 安装PHP# 添加源brew ...
- MUTABLE和IMMUTABLE集合
Scala 集合类系统地区分了可变的和不可变的集合.可变集合可以在适当的地方被更新或扩展.这意味着你可以修改,添加,移除一个集合的元素.而不可变集合类,相比之下,永远不会改变.不过,你仍然可以模拟添加 ...
- storm并发机制,通信机制,任务提交
一.storm的并发 (1)Workers(JVMs):在一个物理节点上可以运行一个或多个独立的JVM进程.一个Topology可以包含一个或多个worker(并行的跑在不同的物理机上),所以work ...
- notification 是同步的
所有notification的观察者执行之后,post notification的函数才会往下执行.
- Web前端开发推荐阅读书籍、学习课程下载
转自http://www.xuanfengge.com/fe-books.html 前言 学校里没有前端的课程,那如何学习JavaScript,又如何使自己成为一个合格的前端工程师呢? 除了在项目中学 ...