piyuhan666 @ 2024-09-29 18:55:40
#include<bits/stdc++.h>
using namespace std;
int n,m;
char a[1010][1010];
int f[1010][1010];
int cnt[1010];
void dfs(int x,int y,int z,int h){
if(x<0 || x>=n || y<0 || y>=n || f[x][y]!=-1 || a[x][y]!=a[x][y]){
return;
}
f[x][y]=h;
cnt[h]++;
dfs(x-1,y,!z,h);
dfs(x+1,y,!z,h);
dfs(x,y-1,!z,h);
dfs(x,y+1,!z,h);
}
int main(){
cin>>n>>m;
for(int i=0;i<n;i++){
cin>>a[i];
}
memset(f,-1,sizeof(f));
for(int i=0;i<m;i++){
int x,y;
cin>>x>>y;
x--;
y--;
if(f[x][y]==-1){
dfs(x,y,a[x][y]-'0',i);
}
else{
cnt[i]=cnt[f[x][y]];
}
}
for(int i=0;i<m;i++){
cout<<cnt[i]<<endl;
}
return 0;
}
by lingquan @ 2024-10-01 22:55:42
直接正常BFS做就行