POJ 2386——Lake Counting(DFS)
链接: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)的更多相关文章
- POJ:2386 Lake Counting(dfs)
Lake Counting Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 40370 Accepted: 20015 D ...
- 题解报告:poj 2386 Lake Counting(dfs求最大连通块的个数)
Description Due to recent rains, water has pooled in various places in Farmer John's field, which is ...
- poj 2386:Lake Counting(简单DFS深搜)
Lake Counting Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 18201 Accepted: 9192 De ...
- POJ 2386 Lake Counting(搜索联通块)
Lake Counting Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 48370 Accepted: 23775 Descr ...
- POJ 2386 Lake Counting(深搜)
Lake Counting Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 17917 Accepted: 906 ...
- Poj2386 Lake Counting (DFS)
Lake Counting Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 49414 Accepted: 24273 D ...
- POJ 2386 Lake Counting (简单深搜)
Description Due to recent rains, water has pooled in various places in Farmer John's field, which is ...
- [USACO10OCT]Lake Counting(DFS)
很水的DFS. 为什么放上来主要是为了让自己的博客有一道DFS题解,,, #include<bits/stdc++.h> using namespace std; ][],ans,flag ...
- (Relax DFS专题1.2)POJ 2386 Lake Counting(使用DFS来计算有多少坨东西是连通的)
题目大意:有N*M的矩阵稻田,'W'表示有积水的地方, '.'表示是干旱的地方,问稻田内一共有多少块积水,根据样例很容易得出,积水是8个方向任一方向相连即可. 题目大意:有N*M的矩阵稻田,'W'表示 ...
随机推荐
- library not found for -ljpush-ios-3.2.1错误
很多人在更新pod后报 library not found for -ljpush-ios-3.2.1(举例)错误,这其实是包含版本号类型错误. 究其原因:使用了版本号做库名字,pod升级后 Podf ...
- python控制窗口口字形运动
import win32con import win32gui import time import math notepad = win32gui.FindWindow("Photo_Li ...
- CodeForces gym Nasta Rabbara lct
Nasta Rabbara 题意:简单来说就是, 现在有 n个点, m条边, 每次询问一个区间[ l , r ], 将这个区间的所有边都连上, 如果现在的图中有奇数环, 就输出 “Impossibl ...
- Kafka笔记—可靠性、幂等性和事务
这几天很忙,但是我现在给我的要求是一周至少要出一篇文章,所以先拿这篇笔记来做开胃菜,源码分析估计明后两天应该能写一篇.给自己加油~,即使没什么人看. 可靠性 如何保证消息不丢失 Kafka只对&quo ...
- 运维核心基础知识之——MD5sum校验文件
如何使用MD5sum工具校验你的文件. 演示过程截图: 先给文件创建一个md5值 md5sum oldboy.txt 然后将md5sum生成的md5值写入到一个文件police.log md5sum ...
- js中数组方法大全
js数组方法大全 一:前言 我们在学到js中数组的时候,我们会接触到js中数组的一些方法,这些方法对我们来说,可以很遍历的达到我们想要的结果,但是因为方法比较多,有些方法也不常用,可能会过一段时间就会 ...
- redis之pipeline使用
redis之pipeline 我们要完成一个业务,可能会对redis做连续的多个操作,这有很多个步骤是需要依次连续执行的.这样的场景,网络传输的耗时将是限制redis处理量的主要瓶颈. 那么此时就可以 ...
- apache ignite系列(五):分布式计算
ignite分布式计算 在ignite中,有传统的MapReduce模型的分布式计算,也有基于分布式存储的并置计算,当数据分散到不同的节点上时,根据提供的并置键,计算会传播到数据所在的节点进行计算,再 ...
- 自定义JDBC工具类(配置文件)
import java.io.IOException; import java.io.InputStream; import java.sql.Connection; import java.sql. ...
- Java第二次作业第二题
请编写图像界面程序,用户在第一文本行输入数字,有三个按钮,分别是计算2进制,8进制,16进制,点击其中一个按钮,第一个文本行中的数据转换为相应进制的数显示在第二个文本行中. package naizi ...