博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
POJ 2386 Lake Counting(DFS)
阅读量:6210 次
发布时间:2019-06-21

本文共 1151 字,大约阅读时间需要 3 分钟。

题意:有一个大小为N×M的园子,雨后积起了水。八连通的积水被认为是连在一起的。求园子里一共有多少水洼?

* * *

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

* * *

Sample Input

10 12W........WW..WWW.....WWW....WW...WW..........WW..........W....W......W...W.W.....WW.W.W.W.....W..W.W......W...W.......W.

Sample Output

3 PS:样例中的3个水洼分别是在左上,左下,和右方。 这是的一道入门的深度优先搜索题,很简单~~ 从任意的W开始,不停地把邻接的部分(八连通)用'.'代替。1次DFS后与初始的这个W连接的所有W就都被替换成了'.',因此直到图中不在存在W为止,总共进行DFS的次数就是答案了。8个方向的共对应了8种状态转移,每个格子作为DFS的参数至多被调用一次,所以复杂度为O(8×M×N)=O(M×N)。
#include
#include
using namespace std;char field[105][105];int N,M;void dfs(int x, int y){ //现在的位置(x,y) field[x][y] = '.';//将现在所在位置替换为'.' for (int dx = -1; dx <= 1; dx++)//循环遍历连通的8个方向 { for (int dy = -1; dy <= 1; dy++) { int nx = x + dx, ny = y + dy;//向x方向移动dx,向y方向移动dy,移动的结果为(nx,ny) if (0 <= nx&&nx <= N && 0 <= ny&&ny <= M&&field[nx][ny] == 'W')//判断(nx,ny)是不是在园子里,以及是否有积水 dfs(nx, ny); } }}int main(){ cin >> N >> M; for (int i = 0; i < N; i++) for (int j = 0; j < M; j++) cin >> field[i][j]; int res = 0; for(int i=0;i

 

 
 

 

转载于:https://www.cnblogs.com/orion7/p/6936861.html

你可能感兴趣的文章
将String转化成Stream,将Stream转换成String
查看>>
java路径Java开发中获得非Web项目的当前项目路径
查看>>
【工具使用系列】关于 MATLAB 遗传算法与直接搜索工具箱,你需要知道的事
查看>>
Kali-linux Arpspoof工具
查看>>
PDF文档页面如何重新排版?
查看>>
基于http协议使用protobuf进行前后端交互
查看>>
bash腳本編程之三 条件判断及算数运算
查看>>
php cookie
查看>>
linux下redis安装
查看>>
弃 Java 而使用 Kotlin 的你后悔了吗?| kotlin将会是最好的开发语言
查看>>
JavaScript 数据类型
查看>>
量子通信和大数据最有市场突破前景
查看>>
StringBuilder用法小结
查看>>
对‘初学者应该选择哪种编程语言’的回答——计算机达人成长之路(38)
查看>>
如何申请开通微信多客服功能
查看>>
Sr_C++_Engineer_(LBS_Engine@Global Map Dept.)
查看>>
非监督学习算法:异常检测
查看>>
《OSPF和IS-IS详解》一2.7 BGP-IGP的路由交换
查看>>
App开发中甲乙方冲突会闹出啥后果?H5 APP 开发可以改变现状吗
查看>>
leetcode | Text Justification
查看>>