[算法提高] DFS 深度优先搜索 数岛屿连通块面积

[问题背景]

假设'#'是陆地,'.'是海洋。

我们从图中把左、上、右、下四个方向相邻的'#'连起来作为一个连通块,也就是一个“岛屿”,每个岛屿的面积就是'#'的个数。

如图:

图中有三个连通块,按自左向右再自上而下的顺序,三个连通块的面积依次是4、2、1.

输出这些连通块的面积。

[测试样例1]

##.#.
#..#.
#...#

[输出样例1]

4 2 1

[测试样例2]

##.#..
#..#..
#...#.
###...
#....#

[输出样例2]

8 2 1 1

[测试样例3]

###..#
#.#...
###...
......
###.##
#.#.#.

[输出样例3]

8 1 5 3

[思路分析]

以左边的连通块为例,应能实现这样的递归访问,每次递归时都将面积+1

我们对二维数组中的元素进行遍历循环,遇到#就开始深搜,搜完一整个连通块后返回整个大循环,继续遍历后面的元素。 

[代码求解]

以下是针对测试样例3编写的代码。

#define N 6
#define M 6
#include <iostream>
#include <vector>
using namespace std;

void dfs(int, int); // 声明深搜dfs函数 

// 在main()之外声明的都是全局变量,main()后面的函数也可以使用这些全局变量 
char c[N][M]; // 记录#.图 
vector<int>area; // 记录各个连通块的面积 
int sum = 0; // 置面积初值为0 
int vis[N][M] = {0}; //记录每个元素是否被访问过,初值0表示没有访问过 

int main(){
    //int N, M; //N行M列 
    //cin >> N >> M;
    //因为传长度为变量的二维数组给函数的问题本人还没有解决,所以很抱歉只能用宏定义的方法做 
    
    //记录#.图 
 
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值