卡码网KamaCoder 99. 岛屿数量

题目来源:99. 岛屿数量

C++题解:来源代码随想录

懒得自己写了。直接搬运。。。

1. 深度优先搜索:它的循环在main函数里,遍历每个位置,判断 是否为陆地 及 是否访问过。

#include <iostream>
#include <vector>
using namespace std;

int dir[4][2] = {0, 1, 1, 0, -1, 0, 0, -1}; // 四个方向
void dfs(const vector<vector<int>>& grid, vector<vector<bool>>& visited, int x, int y) {
    for (int i = 0; i < 4; i++) {
        int nextx = x + dir[i][0];
        int nexty = y + dir[i][1];
        if (nextx < 0 || nextx >= grid.size() || nexty < 0 || nexty >= grid[0].size()) continue;  // 越界了,直接跳过
        if (!visited[nextx][nexty] && grid[nextx][nexty] == 1) { // 没有访问过的 同时 是陆地的

            visited[nextx][nexty] = true;
            dfs(grid, visited, nextx, nexty);
        }
    }
}

int main() {
    int n, m;
    cin >> n >> m;
    vector<vector<int>> grid(n, vector<int>(m, 0));
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < m; j++) {
            cin >> grid[i][j];
        }
    }

    vector<vector<bool>> visited(n, vector<bool>(m, false));

    int result = 0;
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < m; j++) {
            if (!visited[i][j] && grid[i][j] == 1) {
                visited[i][j] = true;
                result++; // 遇到没访问过的陆地,+1
                dfs(grid, visited, i, j); // 将与其链接的陆地都标记上 true
            }
        }
    }

    cout << result << endl;
}

2. 广度优先搜索:将要访问的节点放入队列,一直递归调用bfs函数,直到队列为空,完成每个节点的访问。

#include <iostream>
#include <vector>
#include <queue>
using namespace std;

int dir[4][2] = {0, 1, 1, 0, -1, 0, 0, -1}; // 四个方向
void bfs(const vector<vector<int>>& grid, vector<vector<bool>>& visited, int x, int y) {
    queue<pair<int, int>> que;
    que.push({x, y});
    visited[x][y] = true; // 只要加入队列,立刻标记
    while(!que.empty()) {
        pair<int ,int> cur = que.front(); que.pop();
        int curx = cur.first;
        int cury = cur.second;
        for (int i = 0; i < 4; i++) {
            int nextx = curx + dir[i][0];
            int nexty = cury + dir[i][1];
            if (nextx < 0 || nextx >= grid.size() || nexty < 0 || nexty >= grid[0].size()) continue;  // 越界了,直接跳过
            if (!visited[nextx][nexty] && grid[nextx][nexty] == 1) {
                que.push({nextx, nexty});
                visited[nextx][nexty] = true; // 只要加入队列立刻标记
            }
        }
    }
}

int main() {
    int n, m;
    cin >> n >> m;
    vector<vector<int>> grid(n, vector<int>(m, 0));
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < m; j++) {
            cin >> grid[i][j];
        }
    }

    vector<vector<bool>> visited(n, vector<bool>(m, false));

    int result = 0;
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < m; j++) {
            if (!visited[i][j] && grid[i][j] == 1) {
                result++; // 遇到没访问过的陆地,+1
                bfs(grid, visited, i, j); // 将与其链接的陆地都标记上 true
            }
        }
    }


    cout << result << endl;
}

相关推荐

  1. 刷题Day54|99. 岛屿数量、100. 岛屿的最大面积

    2024-07-13 17:30:01       26 阅读
  2. 200. 岛屿数量

    2024-07-13 17:30:01       50 阅读
  3. c++计算岛屿数量

    2024-07-13 17:30:01       45 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-13 17:30:01       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-13 17:30:01       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-13 17:30:01       58 阅读
  4. Python语言-面向对象

    2024-07-13 17:30:01       69 阅读

热门阅读

  1. git切换远程仓库地址

    2024-07-13 17:30:01       23 阅读
  2. 自动发送每日电子邮件报告的 Python 脚本

    2024-07-13 17:30:01       16 阅读
  3. 使用Spring Boot集成Zipkin分布式追踪

    2024-07-13 17:30:01       18 阅读
  4. Flink实时开发添加水印的案例分析

    2024-07-13 17:30:01       19 阅读
  5. json保存文件乱码

    2024-07-13 17:30:01       21 阅读
  6. 神经网络——数据预处理

    2024-07-13 17:30:01       21 阅读
  7. C 标准库 - <stdio.h>

    2024-07-13 17:30:01       19 阅读
  8. 等保2.0对云计算有哪些特定的安全要求?

    2024-07-13 17:30:01       19 阅读
  9. [Spring Boot]Rest服务调用远程Get、Post请求

    2024-07-13 17:30:01       20 阅读
  10. 今日科技圈最新时事新闻(2024年7月12日

    2024-07-13 17:30:01       21 阅读
  11. Leetcode刷题4--- 寻找两个正序数组的中位数 Python

    2024-07-13 17:30:01       21 阅读