【算法速刷(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;
    }
相关推荐
梓䈑7 分钟前
【C++】C++11(右值引用和移动语义、可变参数模板 和 包装器)
java·开发语言·c++
好评1247 分钟前
【C++】一篇吃透容器适配器三件套:从stack/queue/priority_queue到deque底层
c++·stl·queue·stack
CoovallyAIHub8 分钟前
南京理工大学联手百度、商汤科技等团队推出Artemis:用结构化视觉推理革新多模态感知
深度学习·算法·计算机视觉
天才少女爱迪生10 分钟前
图像序列预测有什么算法方案
人工智能·python·深度学习·算法
cici1587413 分钟前
3D有限元直流电阻率法正演程序
算法·3d
测试人社区—小叶子17 分钟前
Rust会取代C++吗?系统编程语言的新较量
运维·开发语言·网络·c++·人工智能·测试工具·rust
黑色的山岗在沉睡17 分钟前
滤波算法数学前置——线性化
线性代数·算法
t1987512819 分钟前
火电机组热经济性分析MATLAB程序实现
人工智能·算法·matlab
进击的荆棘25 分钟前
C++起始之路——类和对象(中)
开发语言·c++
Hello娃的28 分钟前
【半导体】肖特基接触AND欧姆接触
人工智能·算法