DFS的八联通题:Lake Counting (POJ No.2386)

Lake Counting (POJ No.2386)

问题描述

有一个大小为NM的园子,雨后积起了水。八联通的积水被认为是连接在一起的。请求出园子里总共有多少水洼?(八联通指的是下图中相对W的的部分)

* * *
*W*
* * *

限制条件

N,M<=100

Sample

Input

N=10,M=12

W********WW*
*WWW*****WWW
****WW***WW*
*********WW*
*********W**
**W******W**
*W*W*****WW*
W*W*W*****W*
*W*W******W*
**W*********

Output

3

想法

从任意的W开始,不停地把邻接的部分用’*'代替。

1次DFS后与初始的这个W连接的所有W就都被替换成立’’,因此直到途中不再存在W为止,总共进行DFS的次数就是答案。8个方向共对应了8种状态转移,每个格子作为DFS的参数至多被调用一次,所以复杂的为O(8NM)=O(NM)

代码

//输入
int N,M;
char field[MAX_N][MAX_M+1];

//现在位置(x,y)
void dfs(int x,int y){
    //将现在所在位置替换为*
    field[x][y]='*';
    
    //循环遍历移动的8个方向
    for(int dex=-1;dx<=1;dx++)
    {
    	for(itn dy=-1;dy<=1;dy++)
    	{
			//向x方向移动dx,向y方向移动dy,移动结果为(nx,ny)
			int nx=x+dx,ny=y+dy;
			//判断(nx,ny)是不是在园子内,以及是否有积水
			if(0<=nx&&nx<N&&0<=ny&&nu<M&&field[nx][ny]=='W')
				dfs(nx,ny);
		}
	}
    return ;
}
void solve()
{
	int res=0;
	for(int i=0;i<N;i++)
	{
		for(int j=0;j<M;j++)
		{
			if(field[i][j]=='W')
			{
				//从有W的地方开始dfs
				dfs(i,j);
				res++;
			}
		}
	}
    cout<<res<<endl;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值