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'表示 ...
随机推荐
- ASP.NET Core 3.0中使用动态控制器路由
原文:Dynamic controller routing in ASP.NET Core 3.0 作者:Filip W 译文:https://www.cnblogs.com/lwqlun/p/114 ...
- hihocoder #1608 : Jerry的奶酪(状压dp)
题目链接:http://hihocoder.com/problemset/problem/1608 题解:就是一道简单的状压dp由于dfs过程中只需要几个点之间的转移所以只要预处理一下几个点就行. # ...
- codeforces 807 E. Prairie Partition(贪心+思维)
题目链接:http://codeforces.com/contest/807/problem/E 题意:已知每个数都能用x=1 + 2 + 4 + ... + 2k - 1 + r (k ≥ 0, 0 ...
- PAT L3-015. 球队“食物链”
L3-015. 球队“食物链” 时间限制 1000 ms 内存限制 262144 kB 代码长度限制 8000 B 判题程序 Standard 作者 李文新(北京大学) 某国的足球联赛中有N支参赛球队 ...
- Python基础:Python运行的两种基本方式
完成Python的安装之后,我们可以开始编写Python代码以及运行Python程序了.我们来看一下运行Python具体有哪几种方式 1.REPL 所谓REPL即read.eva.print.loop ...
- Go依赖管理及Go module使用
Go语言的依赖管理随着版本的更迭正逐渐完善起来. 依赖管理 为什么需要依赖管理 最早的时候,Go所依赖的所有的第三方库都放在GOPATH这个目录下面.这就导致了同一个库只能保存一个版本的代码.如果不同 ...
- Spring Cloud(一):服务注册与发现
Spring Cloud是什么 Spring Cloud是一系列框架的有序集合.它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册.配置中心.消息总线.负载均 ...
- Jenkins流水线(pipeline)实战之:从部署到体验
关于Jenkins流水线(pipeline) Jenkins 流水线 (pipeline) 是一套插件,让Jenkins可以实现持续交付管道的落地和实施. 关于blueocean Blue Ocean ...
- Unity基础:AR(增强现实)的学习
版权申明: 本文原创首发于以下网站: 博客园『优梦创客』的空间:https://www.cnblogs.com/raymondking123 优梦创客的官方博客:https://91make.top ...
- 在JSP页面用EL表达式获取数据
<h4>获取域对象中的值</h4><% request.setAttribute("name", "射雕英雄传"); ...