POJ 2386 经典的BFS/DFS

4 篇文章 0 订阅

题意

说白了就是检测连通性,题目给出干的地面和湿的地面。
我们编写DFS检测连通性,从W进入,走过的路都标记成.,看看能进行几次DFS,就是最终答案。注意这里需要检测8个方向。

AC代码

#include<cstdio>

void dfs(int,int);
int n,m;
char f[110][110];

int main(){
    scanf("%d %d\n",&n,&m);
    for(int i=0;i<n;++i){
        for(int j=0;j<m;++j){
            scanf("%c",&f[i][j]);
        }
        getchar();
    }

    int cnt=0;

    for(int i=0;i<n;++i){
        for(int j=0;j<m;++j){
            if(f[i][j]=='W'){
                dfs(i,j);
                ++cnt;
            }
        }
    }
    printf("%d",cnt);
    return 0;
}

void dfs(int x,int y){//8个方位检测连通性,走过的路都标记成'.'
    f[x][y]='.';
    int nx,ny;//记录新位置
    for(int i=-1;i<=1;++i){
        for(int j=-1;j<=1;++j){
            nx=x+i;ny=y+j;
            if((0 <= nx && nx < n)&&( 0 <= ny && ny < m)&&( f[nx][ny]== 'W')){
                dfs(nx,ny);
            }
        }
    }
    return ;
}

这里需要注意的是,如果你使用的是scanf读入数组的话,请不要遗漏每一行的换行符,否则就会导致读入的数组出现问题=,笔者因此改了好久的Bug😢

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值