dfs36分求助

P8662 [蓝桥杯 2018 省 AB] 全球变暖

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,深度搜索如果搜到#说明这部分没被完全淹没就可以了


|