记录编号 598221 评测结果 AAAAAAAAAAAAAAAAAAAA
题目名称 [入门经典] 黑白图像 最终得分 100
用户昵称 GravatarTeaWine 是否通过 通过
代码语言 C++ 运行时间 0.303 s
提交时间 2025-01-22 17:21:44 内存使用 6.17 MiB
显示代码纯文本
#include<bits/stdc++.h>
using namespace std;

int fx[10]={1,1,1,0,0,-1,-1,-1},fy[10]={1,0,-1,1,-1,1,0,-1};

int n,num,ds[1086][1086];
string a[1086];

void fd(int x,int y){
    if(x>n||x<1||y>n|y<1)return ;
    ds[x][y]=1;
    
    for(int i = 0; i<8; i++){
        int nx=x+fx[i],ny=y+fy[i];
        if(a[nx][ny]=='1'&&ds[nx][ny]==0)fd(nx,ny);
    }
}

int main () {
    
    freopen("common.in","r",stdin);
    freopen("common.out","w",stdout);
    
    cin>>n;
    
    for(int i = 1; i<=n; i++){
        string u;
        cin>>u;
        a[i]=' ';
        a[i]+=u;
        a[i]+=' '; 
    }
    
    for(int i = 1; i<=n; i++){
        for(int l = 1; l<=n; l++){
            if(ds[i][l]==0&&a[i][l]=='1'){
                fd(i,l);   
                num++;
            }
        }
    }
    cout<<num;
    return 0;
}