cza2023 @ 2024-01-12 12:57:47
#include<bits/stdc++.h>
using namespace std;
int a[1001][1001],aa[1001][1001];
int dx[]={1,-1,0,0};
int dy[]={0,0,-1,1};
void dfs(int x,int y){
aa[x][y]=0;
for(int i=0;i<4;i++){
int xx=x+dx[i],yy=y+dy[i];
if(aa[xx][yy])dfs(xx,yy);
}
}
void dfs1(int x,int y){
a[x][y]=0;
for(int i=0;i<4;i++){
int xx=x+dx[i],yy=y+dy[i];
if(a[xx][yy]==1)dfs1(xx,yy);
}
}
int main(){
int n,c=0,c1=0;
char t;
cin>>n;
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
cin>>t;
if(t=='#')a[i][j]=1;
aa[i][j]=a[i][j];
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(aa[i][j])dfs(i,j),c++;
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(((!a[i][j-1]&&(j-1))||(!a[i][j+1]&&(j+1<=n))||(!a[i-1][j]&&(i-1))||(!a[i+1][j]&&(i+1<=n)))&&a[i][j])a[i][j]=2;
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(a[i][j]==1)dfs1(i,j),c1++;
}
}
cout<<c-c1;
}
by ge_yiyang_001_DT @ 2024-01-31 14:54:43
你想一下,有一些岛屿在海水上涨的时候可能会变成两个岛屿对吧,但是你这里使用减法。
by shadow_leader @ 2024-02-10 21:54:16
把淹没的部分想象成1,深度搜索如果搜到#说明这部分没被完全淹没就可以了