力扣HOT100之图论:200. 岛屿数量

这道题虽然在力扣上没做过,但是之前刷代码随想录的时候在卡码网上刷过,属于是图论的入门模板题,可以参考我之前的这篇博客,里面的思路写的还是挺详细的。我们需要定义一个方向数组,对应着4个移动方向,另外,我们还需要定义dfs函数来探索岛屿,在地图上移动的过程中,当我们遇到一块从未遇到的陆地时,我们就调用dfs函数来探索这块陆地,dfs函数的作用就是将当前陆地所在的岛屿全部探索出来,因此,在主函数中,但凡遇到新的陆地,那一定是新的岛屿上的陆地,直接将岛屿数量+1即可。

cpp 复制代码
class Solution {
public:
    int numIslands(vector<vector<char>>& grid) {
        int result = 0;
        //定义四个搜索方向
        vector<vector<int>> dirs = {  //定义4个搜索方向
            {0, 1},  //向右
            {0, -1}, //向左
            {-1, 0}, //向上
            {1, 0}   //向下
        };
        vector<vector<bool>> visited(grid.size(), vector<bool>(grid[0].size(), false));
        //定义深度优先搜索函数
        auto dfs = [&] (this auto&& dfs, vector<vector<char>>& grid, vector<vector<bool>>& visited, int x, int y) -> void{
            //输入参数分别为:陆地和水的矩阵、已经探索过的陆地,当前位置的x,y坐标
            for(auto dir : dirs){
                int next_x = x + dir[0];
                int next_y = y + dir[1];
                if((next_x < 0 || next_x >= grid.size()) || next_y < 0 || next_y >= grid[0].size())
                    continue;   //访问越界,直接跳过
                //到达新的陆地
                if(!visited[next_x][next_y] && grid[next_x][next_y] == '1'){
                    visited[next_x][next_y] = true;
                    dfs(grid, visited, next_x, next_y);
                }
            }
        };
        for(int i = 0; i < grid.size(); i++){
            for(int j = 0; j < grid[0].size(); j++){
                if(!visited[i][j] && grid[i][j] == '1'){
                    dfs(grid, visited, i, j);
                    result++;
                }
            }
        }
        return result;
    }
};
相关推荐
点云侠8 分钟前
【2025最新版】PCL点云处理算法汇总(C++长期更新版)
c++·算法·计算机视觉·3d·可视化
zaiyang遇见44 分钟前
【递归完全搜索】CCC 2008 - 24点游戏Twenty-four
算法·游戏·c/c++·全排列·信息学奥赛
Python智慧行囊1 小时前
排序算法总结
数据结构·算法
似水流年流不尽思念1 小时前
常见的排序算法有哪些?它们的平均时间复杂度是多少?
后端·算法
楽码2 小时前
端到端应用Hmac加密
服务器·后端·算法
Morriser莫2 小时前
图论Day2学习心得
算法·图论
KarrySmile2 小时前
Day53--图论--106. 岛屿的周长(卡码网),110. 字符串接龙(卡码网),105. 有向图的完全联通(卡码网)
深度优先·图论·广度优先·广搜·岛屿的周长·字符串接龙·有向图的完全联通
zyd09152 小时前
代码随想录Day50:图论(图论理论、深度搜索理论、所有可达路径、广度搜索理论)
java·数据结构·算法·leetcode·图论
Cl_rown去掉l变成C2 小时前
第R5周:天气预测
人工智能·python·深度学习·算法·tensorflow2
CoovallyAIHub3 小时前
VisDrone数据集,专为无人机视觉任务打造
深度学习·算法·计算机视觉