70分,大佬求调!!!
  • 板块P1141 01迷宫
  • 楼主mab123456
  • 当前回复0
  • 已保存回复0
  • 发布时间2025/1/24 15:42
  • 上次更新2025/1/24 19:22:55
查看原帖
70分,大佬求调!!!
701120
mab123456楼主2025/1/24 15:42
#include<bits/stdc++.h>
using namespace std;
int n,m,sum,ans[1005][1005];
int dx[4]={-1,0,0,1},dy[4]={0,1,-1,0};
char a[1005][1005];
bool b[1005][1005];
void bfs(int x,int y)
{
	queue<pair<int,int> >q;
	q.push({x,y});
	while(!q.empty())
	{
		pair<int,int>p=q.front();
		for(int i=0;i<4;i++)
		{
			int xx=p.first+dx[i],yy=p.second+dy[i];
			if(xx<1||xx>n||yy<1||yy>n)
			continue;
			if(a[xx][yy]!=a[p.first][p.second]&&b[xx][yy]==0)
			{
				sum++;
				b[xx][yy]=1;
				q.push({xx,yy});
			}
		}
		q.pop();
	}
}
int main()
{
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	cin>>n>>m;
	memset(ans,-1,sizeof(ans));
	for(int i=1;i<=n;i++)
	for(int j=1;j<=n;j++)
	cin>>a[i][j];
	for(int i=1;i<=m;i++)
	{
		memset(b,0,sizeof(b));
		int x,y;
		cin>>x>>y;
		if(ans[x][y]==-1)
		{
			b[x][y]=1;sum=1;
		    bfs(x,y);
		    ans[x][y]=sum;
		}
		cout<<ans[x][y]<<endl;
	}
	return 0;
}
2025/1/24 15:42
加载中...