比赛 |
板子大赛 |
评测结果 |
AAAAAAAAAAAAAAAAAAAA |
题目名称 |
黑白图像 |
最终得分 |
100 |
用户昵称 |
xxz |
运行时间 |
0.410 s |
代码语言 |
C++ |
内存使用 |
3.80 MiB |
提交时间 |
2025-01-22 09:27:37 |
显示代码纯文本
#include<bits/stdc++.h>
using namespace std;
char mp[711][711];bool vis[711][711];
int dx[9]={0,1,-1,1,0,-1,0,1,-1},dy[9]={0,1,-1,0,1,0,-1,-1,1};
int m,n,ans;
struct Node{
int x;int y;
};
void bfs(int x,int y){
queue<Node>q;
q.push({x,y});
vis[x][y]=1;
while(!q.empty()){
Node c=q.front();
q.pop();
for(int i=1;i<=8;i++){
int fx=c.x+dx[i];int fy=c.y+dy[i];
if(fx>=1&&fx<=n&&fy>=1&&fy<=n&&vis[fx][fy]==0&&mp[fx][fy]!='0'){
vis[fx][fy]=1;
q.push({fx,fy});
}else continue;
}
}
}
int main(){
freopen("common.in","r",stdin);freopen("common.out","w",stdout);
scanf("%d",&n);
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
cin>>mp[i][j];
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(mp[i][j]!='0'&&vis[i][j]==0){
bfs(i,j);
ans++;
}
}
}
printf("%d",ans);
return 0;
}