芝士不拉丝 • 1年前
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; }
评论:
请先登录,才能进行评论