WHY 0
  • 板块P1141 01迷宫
  • 楼主piyuhan666
  • 当前回复0
  • 已保存回复0
  • 发布时间2024/9/29 18:55
  • 上次更新2024/9/29 21:07:16
查看原帖
WHY 0
1340578
piyuhan666楼主2024/9/29 18:55
#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;
}
2024/9/29 18:55
加载中...