博客
关于我
Lake Counting
阅读量:794 次
发布时间:2023-01-30

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

为了计算农场中的池塘数量,我们可以使用广度优先搜索(BFS)来探索每个连通区域。以下是详细的步骤和代码实现。

方法思路

  • 读取输入:首先读取输入,获取矩阵的大小N和M,然后读取N行的数据,存储到二维数组中。
  • 初始化已访问数组:为了跟踪哪些格子已经被访问,我们创建一个与二维数组同样大小的布尔数组visited
  • 遍历矩阵:对每一个格子,检查是否是水('W')且未被访问过。如果是,则进行BFS,将所有连通的水格子标记为已访问,并计数加一。
  • 广度优先搜索(BFS):BFS使用队列来逐层扩展,处理当前节点及其相邻节点。如果邻居是未被访问的水格子,则加入队列并标记为已访问。
  • 返回结果:当所有未被访问的水格子都被处理完毕,返回池塘的总数。
  • 解决代码

    #include 
    #include
    using namespace std;int main() { int n, m; scanf("%d %d", &n, &m); char grid[n][m]; for (int i = 0; i < n; ++i) { scanf("%s", grid[i]); } bool visited[n][m] = {false}; int count = 0; //八个方向的移动方向 int dirs[8][2] = {{-1, -1}, {-1, 0}, {-1, 1}, {0, -1}, {0, 1}, {1, -1}, {1, 0}, {1, 1}}; for (int i = 0; i < n; ++i) { for (int j = 0; j < m; ++j) { if (grid[i][j] == 'W' && !visited[i][j]) { //启动BFS queue
    > q; q.push({i, j}); visited[i][j] = true; while (!q.empty()) { pair
    current = q.front(); q.pop(); for (auto dir : dirs) { int ni = current.first + dir[0]; int nj = current.second + dir[1]; if (ni >= 0 && ni < n && nj >= 0 && nj < m) { if (!visited[ni][nj] && grid[ni][nj] == 'W') { visited[ni][nj] = true; q.push({ni, nj}); } } } } count++; } } } cout << count << endl; return 0;}

    代码解释

  • 读取输入:使用scanf读取N和M的值,然后读取每一行作为grid二维数组的行。
  • 初始化可访问性数组visited数组用于记录每个格子是否已被访问。
  • 遍历矩阵:双重循环遍历每个格子。对于未被访问的水格子,启动BFS。
  • BFS队列处理:使用队列逐个处理当前格子,检查八个方向的邻居。如果邻居是水且未被访问,就标记并加入队列。
  • 计数池塘:每个启动的BFS对应一个池塘,计数加一。计算完成后输出池塘数量。
  • 这种方法确保了每个水池只被计数一次,效率较高,适用于给定的矩阵尺寸。

    转载地址:http://pzgyk.baihongyu.com/

    你可能感兴趣的文章
    00010.02最基础客户信息管理软件(意义类的小项目,练习基础,不涉及数据库)
    查看>>
    00013.05 字符串比较
    查看>>
    UE4 错误列表 error码(只记录我遇到的情况,持续添加,未完成)
    查看>>
    cmd编译.java文件 : java:720: 错误: 编码GBK的不可映射字符 Why ? ? ? ?
    查看>>
    Android 架构组件 – 让天下没有难做的 App
    查看>>
    能解决数据可视化大屏需求的3款可视化工具
    查看>>
    第01问:MySQL 一次 insert 刷几次盘?
    查看>>
    解决微信小程序项目导入的问题:app.json 未找到、 __wxConfig is not defined
    查看>>
    非迅捷|PDF、Word、PPT、Excel、图片等互相在线转换:免费、简单、快速、零错误、无套路
    查看>>
    laravel server error 服务器内部错误
    查看>>
    一道简单的访问越界、栈溢出pwn解题记录
    查看>>
    响应的HTTP协议格式+常见的响应码
    查看>>
    springboot redis key乱码
    查看>>
    解决打开 json 文件中文乱码的问题
    查看>>
    计算机网络基础:PKI(公钥基础设施)
    查看>>
    乒乓球问题
    查看>>
    回溯法介绍
    查看>>
    2025最新智能优化算法:改进型雪雁算法(Improved Snow Geese Algorithm, ISGA)求解23个经典函数测试集
    查看>>
    有了Trae,人人都是程序员的时代来了
    查看>>
    Access restriction: The type FileURLConnection is not accessible due to restriction
    查看>>