【算法速刷(7/100)】LeetCode —— 200.岛屿数量

这题是典型的深搜题,只需要额外记录每个格子是否被搜索过,然后挨个进行陆地的深度搜索即可。(如果要使用lambda进行递归,需要显式指出变量的模板类型,不能使用auto推导)

cpp 复制代码
int numIslands(vector<vector<char>>& grid) {
        //O(n)时间复杂度遍历每一个格子,O(n)的空间复杂度记录每一个位置是否访问过
        //一旦出现陆地且未访问过,数量加一,进行深搜
        //遍历完成返回结果

        int m = grid.size(), n = grid[0].size();
        int res = 0;

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

        function<void(int, int)> dfs = [&](int x, int y)
        {
            if(x < 0 || y < 0 || x >= m || y >= n)
                return;

            if(grid[x][y] == '0' || visited[x][y])
                return;

            visited[x][y] = true;

            dfs(x + 1, y);
            dfs(x - 1, y);
            dfs(x, y + 1);
            dfs(x, y - 1);
        };

        for(int i = 0; i < grid.size(); i++)
        {
            for(int j = 0; j < grid[0].size(); j++)
            {
                if(grid[i][j] == '1' && !visited[i][j])
                {
                    res++;
                    dfs(i, j);
                }
            }
        }

        return res;
    }
相关推荐
Dfreedom.2 分钟前
归一化技术全景指南
深度学习·算法·机器学习·归一化
Genevieve_xiao2 分钟前
【写给新人】在 vscode 中配置适用于算法竞赛背景的 c/c++
c语言·vscode·算法
格林威3 分钟前
工业相机图像高速存储(C++版):直接IO存储方法,附海康相机实战代码!
开发语言·c++·人工智能·数码相机·计算机视觉·视觉检测·工业相机
小此方6 分钟前
Re:从零开始的 C++ STL篇(七)二叉搜索树增删查操作系统讲解(含代码)+key/key-value场景联合分析
开发语言·c++
TracyCoder1239 分钟前
LeetCode Hot100(70/100)—— 322. 零钱兑换
算法·leetcode·职场和发展
2401_8914821712 分钟前
C++中的观察者模式
开发语言·c++·算法
沐雲小哥14 分钟前
bevfomer算法嵌入的tricks
数码相机·算法
wangzy198215 分钟前
一个高效稳定的多边形三角化算法(支持自交和孤岛检测)
算法·图形渲染
添砖java‘’16 分钟前
序列与反序列化
服务器·网络·c++·序列化·反序列化
保持低旋律节奏16 分钟前
第三讲一元函数微分学的概念
算法