链接: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. Android Studio安卓学习笔记(一)安卓与Android Studio运行第一个项目

    一:什么是安卓 1.Android是一种基于Linux的自由及开放源代码的操作系统. 2.Android操作系统最初由AndyRubin开发,主要支持手机. 3.Android一词的本义指“机器人”, ...

  2. python暴力算法快乐数

    编写一个算法来判断一个数是不是"快乐数". 一个"快乐数"定义为:对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和,然后重复这个过程直到这个数变为 ...

  3. net start mysql提示:服务名无效

    1.win+R打开运行窗口,输入services.msc 2.在其中查看mysql的服务名,我的是MySQL55 3.以管理员身份打开cmd,输入net start MySQL55 出现下图,代表my ...

  4. 洛谷P2331 [SCOI2005]最大子矩阵 DP

    P2331 [SCOI2005]最大子矩阵 题意 : 这里有一个n*m的矩阵,请你选出其中k个子矩阵,使得这个k个子矩阵分值之和最大.注意:选出的k个子矩阵不能相互重叠. 第一行为n,m,k(1≤n≤ ...

  5. 共价大爷游长沙 lct 维护子树信息

    这个题目的关键就是判断 大爷所有可能会走的路 会不会经过询问的边. 某一条路径经过其中的一条边, 那么2个端点是在这条边的2测的. 现在我们要判断所有的路径是不是都经过 u -> v 我们以u为 ...

  6. iOS组件化实践

    参考资料: http://wereadteam.github.io/2016/03/19/iOS-Component/#more https://casatwy.com/iOS-Modulizatio ...

  7. mariadb 远程访问报:Host xxx is not allowed to connect to this MariaDb server

    刚开始试的是: 结果报错了,哎,这折腾的. 继续折腾,加个密码试试: 再用Navicat试试,果然成功了.

  8. 数论 Day 12

    数论是个好东西 今天讲的是组合计数 组合计数 组合数学主要是研究一组离散对象满足一定条件的安排的存在性.构造及计数问题.计数理论是狭义组合数学中最基本的一个研究方向,主要研究的是满足一定条件的排列组合 ...

  9. SRAM和DRAM的区别

    一.浅谈关于SRAM和DRAM的区别:https://www.cnblogs.com/nano94/p/4014082.html. 二.ROM.RAM.DRAM.SRAM和FLASH的区别,转自:ht ...

  10. FreeSql (三十四)CodeFirst 迁移说明

    FreeSql 支持 CodeFirst 迁移结构至数据库,这应该是(O/RM)必须标配的一个功能. 与其他(O/RM)不同FreeSql支持更多的数据库特性,而不只是支持基础的数据类型,这既是优点也 ...