题目描述
在一个给定的迷宫中,探寻从指定方块出发,最多能够踏足多少个方块(包括自己所在的方块)。
这个迷宫的特殊之处在于,它只由黑白两种颜色的瓷砖拼接而成,整个迷宫形状是个n×n的方阵。
让我们一起来探索这个奇妙的迷宫的游玩规则:当你在一个黑色的瓷砖上驻足时,你可以选择行进至周围四个方向中的一个白色瓷砖上。而当你站在一个白色的瓷砖上时,你也可以选择向周围四个方向中的一个黑色瓷砖上迈进。
换句话说,你的移动只能在黑白两种瓷砖之间进行,每一次移动都需要改变你所站立的瓷砖颜色。
所以,小酷宝的这个任务的核心,就是要你找出从一个特定的方块出发,经过一系列的黑白瓷砖变换,你最多能踏足多少个方块。
输入
输入的第1行为两个正整数n,m,代表n*n迷宫的大小n,以及m次查询。(1 <=n<=1000, 1<=m<=n*n)
下面n行,每行n个字符,字符只可能是0或者1,字符之间没有空格,也就是说你需要读入n行,每行一个字符串,每个字符串长度为n,其中字符01分别代表黑色瓷砖和白色瓷砖。
接下来m行,每行2个用空格分隔的正整数i,j,对应了迷宫中第i行第j列的一个指定方块,询问从这一个方块开始经过一系列的黑白瓷砖变换最多能踏足多少个方块。
输出
输出包括m行,对于每个询问输出答案。
样例输入
2 2 01 10 1 1 2 2
样例输出
4 4
#include <bits/stdc++.h>
int n,m,ans[100002],x,y,f[1002][1002];
char s[1002][1002];
void dfs(int r,int c,int z,int lll){
if (r<0 || r>=n || c<0 || c>=n || f[r][c]!=-1 || s[r][c]-'0'!=z)return;
f[r][c]=lll;ans[lll]++;
dfs(r-1,c,!z,lll);dfs(r+1,c,!z,lll);dfs(r,c-1,!z,lll);dfs(r,c+1,!z,lll);
}
int main()
{
scanf("%d%d",&n,&m);
for (int i=0;i<n;i++)
scanf("%s",s[i]);
memset(f,-1,sizeof(f));
for (int i=0;i<m;i++)
{
scanf("%d%d",&x,&y);x--;y--;
if (f[x][y]==-1)dfs(x,y,s[x][y]-'0',i);else ans[i]=ans[f[x][y]];
}
for (int i=0;i<m;i++)
printf("%d\n",ans[i]);
return 0;
}