Problem Description
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.
Input
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 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
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.
Sample Input
3 5 6 XXXXXX XZ..ZX XXXXXX M.G... ...... 5 6 XXXXXX XZZ..X XXXXXX M..... ..G... 10 10 .......... ..X....... ..M.X...X. X......... .X..X.X.X. .........X ..XX....X. X....G...X ...ZX.X... ...Z..X..X
Sample Output
题意:一天晚上,小erriyue做了一个可怕的噩梦。他梦见他和他的女朋友被困在一个大的迷宫里。更可怕的是,在迷宫里有两个鬼。他们会杀人。现在小erriyue想知道他能否在鬼找他们前找到他的女朋友。
你可能认为小erriyue和他的女朋友可以在4个方向移动。在每一秒,小erriyue可以移动3步和他的女朋友可以移动1步。鬼是邪恶的,每一秒,他们将分为几个部分,占领距离他们为2的地方,直到他们占据整个迷宫。你可以假设两个鬼鬼先于小erriyue和他的女朋友开始移动,如果小erriyue或他的女朋友到达一个幽灵网格,他们会死。
注:新鬼也可以分身,并且鬼会穿墙。
思路:只要他们到达其中一个人走过的地方就算他们已经相遇。从M、G双向广搜,鬼是先分身,人再移动的,因为M一个单位时间可以移动三步,所以会拓展出来很多新的节点,在每次广搜前,先读入上次的数据判断,两个人分成两个队列进行处理。判断鬼到人距离的时候只要计算人与两个鬼的曼哈顿距离即可。
#include
#include
#include
#include
using namespace std;
int dir[4][2]={1,0,-1,0,0,1,0,-1};
int n,m,step;
char Map[810][810];
struct node
{
int x,y;
}gg,mm,zz[2];
queueq[2],qt;
int judge(node t)
{
//原始鬼到人的距离
for(int i=0;i<2;i++)
if((abs(zz[i].x-t.x)+abs(zz[i].y-t.y))<=2*step||Map[t.x][t.y]=='X'||t.x<0||t.x>=n||t.y<0||t.y>=m)
return 0;
return 1;
}
//男的可以走三步以内的任意步数
int bfs(int mark,int num,char start,char endd)
{
node a,b;
qt=q[mark];//把当前队列付给qt
for(int i=0;i