【算法速刷(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;
    }
相关推荐
Stream几秒前
加密与签名技术之哈希算法
后端·算法
老王熬夜敲代码13 分钟前
泛型编程的差异抽象思想
开发语言·c++·笔记
少许极端18 分钟前
算法奇妙屋(十五)-BFS解决边权为1的最短路径问题
数据结构·算法·bfs·宽度优先·队列·图解算法·边权为1的最短路径问题
c骑着乌龟追兔子30 分钟前
Day 27 常见的降维算法
人工智能·算法·机器学习
hetao173383732 分钟前
2025-12-02~03 hetao1733837的刷题记录
c++·算法
田里的水稻34 分钟前
math_旋转变换
算法·几何学
“愿你如星辰如月”37 分钟前
C++11核心特性全解析
开发语言·c++
ada7_42 分钟前
LeetCode(python)——94.二叉
python·算法·leetcode·链表·职场和发展
广都--编程每日问44 分钟前
c++右键菜单统一转化文件为utf8编码
c++·windows·python
点云SLAM44 分钟前
C++包装器之类型擦除(Type Erasure)包装器之小对象优化(SBO, Small Buffer Optimization)示例(5)
c++·内存管理·c++高级应用·c++包装器·类型擦除包装器·内存小对象优化