okk

芝士不拉丝  •  11个月前


include<bits/stdc++.h>

using namespace std; char a[105][105]; int dy[4]={0,0,-1,1},dx[4]={1,-1,0,0}; int m,n,ans; struct wz{ int x,y; }; bool ina(int x,int y){ return x>=1&&x<=m&&y>=1&&y<=n; } void bfs(int x,int y){ queue q; a[x][y]='0'; q.push({x,y}); while(q.size()!=0){

wz xy=q.front();
q.pop();
for(int i=0;i<4;i++){
	int x1=xy.x+dx[i],y1=xy.y+dy[i];
	if(a[x1][y1]!='0' && ina(x1,y1)){
		q.push({x1,y1});
		a[x1][y1]='0';
	}
}

} } int main(){ cin>>m>>n; for(int i=1;i<=m;i++)

for(int j=1;j<=n;j++)
	cin>>a[i][j];

for(int i=1;i<=m;i++)

for(int j=1;j<=n;j++)
	if(a[i][j]!='0'){
		bfs(i,j);
		ans++;
	}

cout<<ans; return 0; }


评论:

请先登录,才能进行评论