1141救
  • 板块题目总版
  • 楼主QwQ__
  • 当前回复0
  • 已保存回复0
  • 发布时间2022/1/22 14:43
  • 上次更新2023/10/28 11:33:56
查看原帖
1141救
541907
QwQ__楼主2022/1/22 14:43
#include <bits/stdc++.h>
using namespace std;
int n,m;int sum=0;
char a[105][105];
int vis[105][105];
int dx[6]={0,-1,0,1,0};
int dy[654]={0,0,-1,1,1};
struct node{
	int left,right;
};
void bfs(int x,int y){
	queue<node> q;
	q.push((node){x,y});
	vis[x][y]=2;
	while(!q.empty()){
		node now=q.front();
		q.pop();
		for(int i=1;i<=4;i++){
			int tx=now.left+dx[i];
			int ty=now.right+dy[i];
			if(vis[tx][ty]==2)return;
			if(tx>n||ty>n||tx<0||ty<0)return;
			if(a[tx][ty]==a[now.left][now.right])return;
			sum++;vis[tx][ty]=2;
		} 
	}
}
int main(){
	
	cin>>n>>m;
	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++){
		int qwq,pwp;
		cin>>qwq>>pwp;
		bfs(qwq,pwp);
		cout<<sum<<" ";
		sum=0;
	}
	return 0;
}
2022/1/22 14:43
加载中...