题意:链接

分析:每一个D或者是E点往四面延伸,并且赋一个特殊的值,能看到D点的点赋值为1,能看到E点的点赋值为1000,这是因为最多100步,因此最后可以根据除以1000和对1000取模来得出某个状态的值,那么这个数值对应的状态就有四种,BFS搜索即可。之前没有考虑到折回这种情况,原因就是状态没有进行完全的搜索。后面看了网上的写法中多是直接开设了四维的一个状态,只需记录某状态走还是没走,也就没有这种折回的考虑了。

#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <iostream>
#include <algorithm>
#include <queue>
using namespace std; const int N = ;
int n, m, t;
int sx, sy, dx, dy, ex, ey;
char mp[N][N];
int score[N][N];
int dir[][] = {, , , -, , , -, }; struct Node {
int x, y, val, ti;
Node() {}
Node(int _x, int _y, int _val, int _ti) : x(_x), y(_y), val(_val), ti(_ti) {}
}; inline bool judge(int x, int y) {
if (x < || x > n || y < || y > m) return false;
else return true;
} inline int cal(int x) {
int a = (int)(bool(x/));
int b = (int)(bool(x%));
if (a && b) return ;
else if (a) return ;
else if (b) return ;
else return ;
} int lol[N][N]; int solve() {
memset(lol, 0xff, sizeof (lol));
queue<Node>q;
q.push(Node(sx, sy, score[sx][sy], t));
lol[sx][sy] = cal(score[sx][sy]);
while (!q.empty()) {
Node tmp = q.front();
q.pop();
if (lol[tmp.x][tmp.y] == ) return t - tmp.ti;
if (tmp.ti > ) { // 如果还有剩余时间
for (int k = ; k < ; ++k) {
int cx = tmp.x + dir[k][], cy = tmp.y + dir[k][];
int cc = cal(tmp.val + score[cx][cy]);
if (judge(cx, cy) && cc != lol[cx][cy] && mp[cx][cy] == '.') {
lol[cx][cy] = cc;
if (lol[cx][cy] == ) return t-(tmp.ti-);
q.push(Node(cx, cy, tmp.val+score[cx][cy], tmp.ti-));
}
}
}
}
return -;
} int main() {
int T, ca = ;
scanf("%d", &T);
while (T--) {
int cx, cy;
scanf("%d %d %d", &n, &m, &t);
memset(score, , sizeof (score));
for (int i = ; i <= n; ++i) {
scanf("%s", mp[i]+);
for (int j = ; j <= m; ++j) {
if (mp[i][j] == 'S') {
sx = i, sy = j;
mp[i][j] = '.';
} else if (mp[i][j] == 'D') {
dx = i, dy = j;
} else if (mp[i][j] == 'E') {
ex = i, ey = j;
}
}
}
for (int k = ; k < ; ++k) { // 把分数都加到格子上
cx = dx + dir[k][], cy = dy + dir[k][];
while (judge(cx, cy) && mp[cx][cy] == '.') {
score[cx][cy] += ;
cx += dir[k][], cy += dir[k][];
}
cx = ex + dir[k][], cy = ey + dir[k][];
while (judge(cx, cy) && mp[cx][cy] == '.') {
score[cx][cy] += ;
cx += dir[k][], cy += dir[k][];
}
}
printf("Case %d:\n%d\n", ++ca, solve());
}
return ;
}

HDU-4528 小明系列故事——捉迷藏 BFS模拟的更多相关文章

  1. HDU 4528 小明系列故事――捉迷藏

    广搜. 根据题意,可以知道状态总共有$4*n*m$种.每一个位置四种状态:两个都没有发现:发现$E$没发现$D$:发现$D$没发现$E$:两个都发现. 每次移动的花费都是$1$,队列里面状态的费用是单 ...

  2. HDU 4828 小明系列故事——捉迷藏

    漂亮妹子点击就送:http://acm.hdu.edu.cn/showproblem.php?pid=4528 Time Limit: 500/200 MS (Java/Others)    Memo ...

  3. HDU 4528 BFS 小明系列故事——捉迷藏

    原题直通车:HDU 4528 小明系列故事——捉迷藏 分析: 标记时加两种状态就行. 代码: #include<iostream> #include<cstring> #inc ...

  4. C - 小明系列故事――捉迷藏 HDU - 4528 bfs +状压 旅游-- 最短路+状压

    C - 小明系列故事――捉迷藏 HDU - 4528 这个题目看了一下题解,感觉没有很难,应该是可以自己敲出来的,感觉自己好蠢... 这个是一个bfs 用bfs就很好写了,首先可以预处理出大明和二明能 ...

  5. hdu 4506 小明系列故事——师兄帮帮忙【幂取模乱搞】

    链接: http://acm.hdu.edu.cn/showproblem.php?pid=4506 http://acm.hust.edu.cn/vjudge/contest/view.action ...

  6. hdu 4542 小明系列故事——未知剩余系

    小明系列故事——未知剩余系 题意:操作0表示某数有n个约数,操作1为某数有n个非约数:n <= 47777,若是存在小于2^62的数符合,则输出该数,否则若是不存在输出Illegal,若是大于2 ...

  7. HDU 4511 小明系列故事——女友的考验 (AC自动机+DP)

    小明系列故事——女友的考验 Time Limit: 500/200 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total ...

  8. HDU 4511 小明系列故事——女友的考验 (AC自动机 + DP)

    小明系列故事——女友的考验 Time Limit: 500/200 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total ...

  9. hdu 4542 小明系列故事——未知剩余系 反素数 + 打表

    小明系列故事——未知剩余系 Time Limit: 500/200 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others) Prob ...

随机推荐

  1. 一键发布ASP.NET Web安装程序

    转载自:http://www.cnblogs.com/nangong/p/Web.html        前言:最近公司有个Web要发布,但是以前都是由实施到甲方去发布,配置,这几天有点闲,同事让我搞 ...

  2. JSON和JS对象之间的互转(转)

    文章出处:http://www.cnblogs.com/dyllove98/p/4235909.html 1. jQuery插件支持的转换方式 $.parseJSON( jsonstr ); //jQ ...

  3. 【转】NGUI研究院之为什么打开界面太慢(十三)

    NGUI打开界面太慢了,起初一直以为是unity的问题,最近经过我的全面测试我发现这和unity没有关系.一般一个比较复杂的界面大概需要150个GameObject  或者 UISprite .我用N ...

  4. JQuery-属性

    // attr能访问到的都是html里面的样式,诸如内联样式.外部样式和外联样式该方法访问不到 $('#div1').width('400px') // 这个用来改样式css $("#div ...

  5. Matlab代码备忘

    1.Matlab写入文件  set(hp1,'xdata',bbb(1,:),'ydata',bbb(2,:),'zdata',bbb(3,:)); M=size(bbb,2); name=strca ...

  6. ios - 文件保存路径的获取

    "应用程序包": 这里面存放的是应用程序的源文件,包括资源文件和可执行文件. 获取方式: NSString *path = [[NSBundle mainBundle] bundl ...

  7. ios -- 教你如何轻松学习Swift语法(一)

    目前随着公司开发模式的变更,swift也显得越发重要,相对来说,swift语言更加简洁,严谨.但对于我来说,感觉swift细节的处理很繁琐,可能是还没适应的缘故吧.基本每写一句代码,都要对变量的数据类 ...

  8. C++ DateTime 结构

    OS:Win7 ,Tools:VS2015 DateTime.h #pragma once struct DateTime { public: unsigned Year; // years sinc ...

  9. 1046: 最小的K个数

    1046: 最小的K个数 时间限制: 1 Sec  内存限制: 128 MB提交: 233  解决: 200[提交][状态][讨论版] 题目描述 输入n个整数,找出其中最小的K个数.例如输入4,5,1 ...

  10. c++ type_info and typeid

    c++ type_info and typeid typeid 关键字typeid提供了对一个对象查询类型的功能. 该关键字和dynami_cast一起提供了c++的RTTI(rumtime type ...