HDU3085 Nightmare Ⅱ
题目:
Last night, little erriyue had a horrible nightmare. He dreamed that he and his girl friend were trapped in a big maze separately. More terribly, there are two ghosts in the maze. They will kill the people. Now little erriyue wants to know if he could find his girl friend before the ghosts find them.
You may suppose that little erriyue and his girl friend can move in 4 directions. In each second, little erriyue can move 3 steps and his girl friend can move 1 step. The ghosts are evil, every second they will divide into several parts to occupy the grids within 2 steps to them until they occupy the whole maze. You can suppose that at every second the ghosts divide firstly then the little erriyue and his girl friend start to move, and if little erriyue or his girl friend arrive at a grid with a ghost, they will die.
Note: the new ghosts also can devide as the original ghost.
输入:
The input starts with an integer T, means the number of test cases.
Each test case starts with a line contains two integers n and m, means the size of the maze. (1<n, m<800)
The next n lines describe the maze. Each line contains m characters. The characters may be:
‘.’ denotes an empty place, all can walk on.
‘X’ denotes a wall, only people can’t walk on.
‘M’ denotes little erriyue
‘G’ denotes the girl friend.
‘Z’ denotes the ghosts.
It is guaranteed that will contain exactly one letter M, one letter G and two letters Z.
输出:
Output a single integer S in one line, denotes erriyue and his girlfriend will meet in the minimum time S if they can meet successfully, or output -1 denotes they failed to meet.
样例:
分析:cin cout加std::ios::sync_with_stdio(false);都过不去(/‵Д′)/~ ╧╧,换scanf就ac了?!
双向BFS,预处理鬼什么时候覆盖该位置(貌似博客题解都是用曼哈顿距离?明明预处理更明显想到(ctrl c + v?))
记住鬼在人前行动,对照样例3理解这句话
#include<iostream>
#include<sstream>
#include<cstdio>
#include<cstdlib>
#include<string>
#include<cstring>
#include<algorithm>
#include<functional>
#include<iomanip>
#include<numeric>
#include<cmath>
#include<queue>
#include<vector>
#include<set>
#include<cctype>
#define PI acos(-1.0)
const int INF = 0x3f3f3f3f;
const int NINF = -INF - ;
typedef long long ll;
using namespace std;
typedef pair<int, int> P;
char maze[][];
int n, m;
int mx, my, gx, gy;
P z[];
int timz[][];
int visz[][];
int dzx[] = {, , , , -, -, , , , , -, -}, dzy[] = {, , , , , , -, -, , -, , -};
void ini()
{
for (int i = ; i < n; ++i)
{
for (int j = ; j < m; ++j)
timz[i][j] = INF;
}
for (int i = ; i < n; ++i)
{
for (int j = ; j < m; ++j)
visz[i][j] = ;
}
queue<P> p;
timz[z[].first][z[].second] = ;
timz[z[].first][z[].second] = ;
visz[z[].first][z[].second] = ;
visz[z[].first][z[].second] = ;
p.push(z[]);
p.push(z[]);
while (p.size())
{
P tmp = p.front();
p.pop();
for (int i = ; i < ; ++i)
{
int nx = tmp.first + dzx[i], ny = tmp.second + dzy[i];
if (nx >= && nx < n && ny >= && ny < m && !visz[nx][ny])
{
visz[nx][ny] = ;
timz[nx][ny] = timz[tmp.first][tmp.second] + ;
p.push(P(nx, ny));
}
}
}
}
int dx[] = {, , -, }, dy[] = {, , , -};
int vis[][][];
queue<P> q[];
int step;
int bfs(int flag)
{
int num = q[flag].size();
while (num--)
{
P tmp = q[flag].front();
q[flag].pop();
if (step >= timz[tmp.first][tmp.second]) continue;
for (int i = ; i < ; ++i)
{
int nx = tmp.first + dx[i], ny = tmp.second + dy[i];
if (nx < || nx >= n || ny < || ny >= m || vis[flag][nx][ny] || maze[nx][ny] == 'X' || step >= timz[nx][ny])
continue;
if (vis[ - flag][nx][ny])
{
printf("%d\n", step);
return ;
}
vis[flag][nx][ny] = ;
q[flag].push(P(nx, ny));
}
}
return ;
}
void solve()
{
for (int i = ; i < ; ++i)
{
while (q[i].size()) q[i].pop();
}
memset(vis[], , sizeof(vis[]));
memset(vis[], , sizeof(vis[]));
vis[][mx][my] = ;
vis[][gx][gy] = ;
q[].push(P(mx, my));
q[].push(P(gx, gy));
step = ;
while (q[].size() || q[].size())
{
step++;
for (int i = ; i < ; ++i)
if (bfs()) return;
if (bfs()) return;
}
printf("-1\n");
}
int main()
{
int T;
scanf("%d", &T);
while (T--)
{
scanf("%d%d",&n,&m);
int num = ;
for (int i = ; i < n; ++i)
{
scanf("%s",maze[i]);
for (int j = ; j < m; ++j)
{
if (maze[i][j] == 'M') mx = i, my = j;
if (maze[i][j] == 'G') gx = i, gy = j;
if (maze[i][j] == 'Z') z[num].first = i, z[num++].second = j;
}
}
ini();
solve();
}
return ;
}
HDU3085 Nightmare Ⅱ的更多相关文章
- HDU3085 Nightmare Ⅱ —— 双向BFS + 曼哈顿距离
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3085 Nightmare Ⅱ Time Limit: 2000/1000 MS (Java/Other ...
- HDU3085 Nightmare Ⅱ (双向BFS)
联赛前该练什么?DP,树型,状压当然是爆搜啦 双向BFS就是两个普通BFS通过一拼接函数联系,多多判断啦 #include <iostream> #include <cstdio&g ...
- 【HDU - 3085】Nightmare Ⅱ(bfs)
-->Nightmare Ⅱ 原题太复杂,直接简单的讲中文吧 Descriptions: X表示墙 .表示路 M,G表示两个人 Z表示鬼 M要去找G但是有两个鬼(Z)会阻碍他们,每一轮都是M和G ...
- HDU 1072 Nightmare
Description Ignatius had a nightmare last night. He found himself in a labyrinth with a time bomb on ...
- Nightmare基于phantomjs的自动化测试套件
今天将介绍一款自动化测试套件名叫nightmare,他是一个基于phantomjs的测试框架,一个基于phantomjs之上为测试应用封装的一套high level API.其API以goto, re ...
- POJ 1984 Navigation Nightmare 带全并查集
Navigation Nightmare Description Farmer John's pastoral neighborhood has N farms (2 <= N <= ...
- Nightmare
Nightmare Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total S ...
- hdu 1072 Nightmare (bfs+优先队列)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1072 Description Ignatius had a nightmare last night. H ...
- HDU 3085 Nightmare Ⅱ (双向BFS)
Nightmare Ⅱ Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tota ...
随机推荐
- 【第8篇】:Python之面向对象
python之--------封装 一.封装: 补充封装: 封装: 体现在两点: 1.数据的封装(将数据封装到对象中) obj = Foo('宝宝',22) 2.封装方法和属性,将一类操作封装到一个类 ...
- Mac 执行 gulp 报错 -bash: gulp: command not found
在mac系统下安装gulp,之后执行gulp 报如下错误: -bash: gulp: command not found 回溯安装过程发现问题如下 1.执行 npm root: Application ...
- 【解题报告】 洛谷 P3492 [POI2009]TAB-Arrays
[解题报告] 洛谷 P3492 [POI2009]TAB-Arrays 这题是我随机跳题的时候跳到的.写完这道题之后,顺便看了一下题解,发现只有一篇题解,所以就在这里顺便写一个解题报告了. 首先当然是 ...
- 51nod1006 -最长公共子序列Lcs【动态规划】
给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的). 比如两个串为: abcicba abdkscab ab是两个串的子序列,abc也是,abca也是,其中abca是这两个字符串最 ...
- String s = new String("xyz");创建了几个对象?
两个或一个都有可能 . ”xyz”对应一个对象,这个对象放在字符串常量池,常量”xyz”不管出现多少遍,都是常量池中的那一个. new String每写一遍,就创建一个新的对象,它使用常量”xyz”对 ...
- 关于MySQL中自增的理解和设置
show create table t10;--查看表的创建结果 show create table t10\G;--竖列查看 --设置自增为20 ); insert into t2(name) va ...
- BOM对象和DOM对象
一.BOM对象 BOM(Browser Object Model)是指浏览器对象模型,可以对浏览器窗口进行访问和操作.使用 BOM,开发者可以移动窗口.改变状态栏中的文本以及执行其他与页面内容不直接相 ...
- 29. 误拼写时的fuzzy模糊搜索技术
搜索的时候,可能输入的搜索文本会出现误拼写的情况,这时就需要es为我们进行智能纠错 比如有两个文档: doc1: hello world doc2: hello java 现在要搜索:hall ...
- 【BestCoder Round #93 1001】MG loves gold
[题目链接]:http://acm.hdu.edu.cn/showproblem.php?pid=6019 [题意] 每次选择一段连续的段,使得这一段里面没有重复的元素; 问你最少选多少次; [题解] ...
- sysman 账号 oracle em console的一些问题
前几天用下面的命令修改了 sysman的密码. [oracle@racnode1 ~]$ emctl setpasswd dbconsole Oracle Enterprise Manager 11g ...