链接:http://poj.org/problem?id=2386

题解

#include<cstdio>
#include<stack>
using namespace std;

,MAX_N=;
char a[MAX_N][MAX_M];
int N,M;
//现在位置 (x,y)
void dfs(int x,int y){
    a[x][y]='.'; //将现在所在位置替换为'.',即旱地
    ;dx<=;dx++){ //循环遍历连通的8个方向:上、下、左、右、左上、左下、右上、右下
        ;dy<=;dy++){
            int nx=x+dx,ny=y+dy; //向x方向移动dx,向y方向移动dy,移动的结果为(nx,ny)
            <=nx && nx<N && <=ny && ny<M && a[nx][ny]=='W'){ //判断(nx,ny)是否在园子里,以及是否有积水
                dfs(nx, ny);
            }
        }
    }
}

//每个 W 看成"水渍",满足八连通条件时构成积水;单独一块"水渍"也看成积水
int main(){
    scanf("%d%d",&N,&M);
    ;i<N;++i){
        scanf("%s",a[i]);
    }
    ;
    ;i<N;++i){
        ;j<M;++j){
            if(a[i][j]=='W'){ //只有检测到水渍时才执行该函数
                res++; //凡检测到"水渍",res 先加一,至少这里可以形成水坑 

                //从有 W 的地方开始 dfs
                //dfs 函数的作用是把该点的八连通区域变成旱地,以免后续遍历时重复计数
                //同时通过递归的思想把八连通区域中,每个元素对应的八连通区域遍历一遍,查找是否有其他"水渍"可构成积水
                dfs(i,j);
            }
        }
    }
    printf("%d",res);
    ;
}

本题采用深度优先搜索

遍历数组,从第一个 ' W ' 开始,把它对应的八连通区域中的 ' W ' 用 ' . ' 代替

每调用一次 dfs 函数,与初始的 ' W ' 连通的所有 ' W ' 就全都被替换成 ' . ',直到图中不再存在 ' W ' 为止,总共调用 dfs 函数的次数就是答案

8个方向对应8个状态转移,每个格子作为 dfs 的参数最多调用一次,时间复杂度:O(8 * n * m) = O(n * m)


八连通

*  *  *

* W *    (八连通指的就是左图中相对 W 的 * 的部分)

*  *  *

深度优先搜索(与递归和栈关系密切)

深度优先搜索从某个状态开始,不断地转移状态直到无法转移,然后回退到前一步的状态,继续转移到其它状态;如此不断重复,直到找到最终解

例如求解数独,首先在某个格子内填入适当的数字,然后继续在下一个格子内填入数字,如此重复。如果发现某个格子无解,就放弃前一个格子选择的数字,改用其他可行的数字

深度优先搜索时,有时早已很明确地知道从当前状态无论如何转移都不会存在解。这种情况下,不再继续搜索而直接跳过,该方法称为剪枝

POJ 2386——Lake Counting(DFS)的更多相关文章

  1. POJ:2386 Lake Counting(dfs)

    Lake Counting Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 40370   Accepted: 20015 D ...

  2. 题解报告:poj 2386 Lake Counting(dfs求最大连通块的个数)

    Description Due to recent rains, water has pooled in various places in Farmer John's field, which is ...

  3. poj 2386:Lake Counting(简单DFS深搜)

    Lake Counting Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 18201   Accepted: 9192 De ...

  4. POJ 2386 Lake Counting(搜索联通块)

    Lake Counting Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 48370 Accepted: 23775 Descr ...

  5. POJ 2386 Lake Counting(深搜)

    Lake Counting Time Limit: 1000MS     Memory Limit: 65536K Total Submissions: 17917     Accepted: 906 ...

  6. Poj2386 Lake Counting (DFS)

    Lake Counting Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 49414   Accepted: 24273 D ...

  7. POJ 2386 Lake Counting (简单深搜)

    Description Due to recent rains, water has pooled in various places in Farmer John's field, which is ...

  8. [USACO10OCT]Lake Counting(DFS)

    很水的DFS. 为什么放上来主要是为了让自己的博客有一道DFS题解,,, #include<bits/stdc++.h> using namespace std; ][],ans,flag ...

  9. (Relax DFS专题1.2)POJ 2386 Lake Counting(使用DFS来计算有多少坨东西是连通的)

    题目大意:有N*M的矩阵稻田,'W'表示有积水的地方, '.'表示是干旱的地方,问稻田内一共有多少块积水,根据样例很容易得出,积水是8个方向任一方向相连即可. 题目大意:有N*M的矩阵稻田,'W'表示 ...

随机推荐

  1. Elasticsearch(5)--- 基本命令(集群相关命令、索引CRUD命令、文档CRUD命令)

    Elasticsearch(5)--- 基本命令 这篇博客的命令分为ES集群相关命令,索引CRUD命令,文档CRUD命令.这里不包括Query查询命令,它单独写一篇博客. 一.ES集群相关命令 ES集 ...

  2. 关于AndroidStudio在真机安装的apk闪退(无法打开)的解决方案

    问题描述: 重新安装AndroidStudio之后 1.发现在真机上安装apk时显示的是应用包名. 2.在真机上安装的apk无法打开,一直闪退. 如图: 解决方案: 关闭AndroidStudio的I ...

  3. JOBDU 1109 连通图

    题目1109:连通图 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:4192 解决:2224 题目描述: 给定一个无向图和其中的所有边,判断这个图是否所有顶点都是连通的. 输入: 每组数据 ...

  4. hdu 5902 GCD is Funny

    Problem Description Alex has invented a new game for fun. There are n integers at a board and he per ...

  5. 牛客小白月赛5 D 阶乘 数学

    链接:https://www.nowcoder.com/acm/contest/135/D来源:牛客网 题目描述 输入描述: 输入数据共一行,一个正整数n,意义如“问题描述”. 输出描述: 输出一行描 ...

  6. Atcoder D - Black and White Tree(树dp+博弈)

    题目链接:http://agc014.contest.atcoder.jp/tasks/agc014_d 题意:有一棵树先手涂白色,后手涂黑色,直到不能再涂为止.涂完后再把所有黑色直接相邻的白色都变成 ...

  7. HDU dp递推 母牛的故事 *

    母牛的故事 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  8. springboot的最简创建方式

    springboot是目前比较流行的技术栈之一,我在这里写一个springboot工程最简方式 首先开发工具是IDEA,双击打开IDEA,点击Create new Project 进入到这个页面,选择 ...

  9. C#客户端程序Visual Stadio远程调试

    一,需求来源 在开发过程中,可能会要使用Win7 ,Win8 ,Win10等不同版本的系统去做兼容性调试,也有时候会去针对特别的显卡,无线网卡等等硬件设备的机器做优化,有一种较优的方案,那就是使用Vi ...

  10. ubuntu16.04设置bind9.10.3的chroot运行

    重点:1)系统是ubuntu的16.04 bind9.10.3 2)确保你的系统是没问题的,我之前的16.04有问题,在虚拟机上怎么都操作都不行, 在/var/log/syslog可以看到:could ...