Leetcode200. 岛屿数量(HOT100)

链接

代码:

cpp 复制代码
class Solution {
public:
    int dx[4] = {0,1,-1,0},dy[4] = {1,0,0,-1};
    vector<vector<char>> g;
    int numIslands(vector<vector<char>>& grid) {
        g = grid;
        int cnt = 0;
        for(int i = 0;i<g.size();i++){
            for(int j = 0;j<g[i].size();j++){//g[i].size() rather than g[0].size()
                if(g[i][j]=='1'){
                    dfs(i,j);
                    cnt++;
                }
            }
        }
        return cnt;
    }
    void dfs(int x,int y){//not int i,int y 否则会和内层for循环中的i冲突
        g[x][y] = '0';
        for(int i = 0;i<4;i++){
            int a = x+dx[i],b = y+dy[i];
            if(a>=0 && b>=0 
                    && a<g.size() && b<g[a].size() //not a<=g.size() && b<=g[i].size()
                    && g[a][b]=='1')//g[i].size() rather than g[0].size()
                dfs(a,b);
        }
    }
};

这是flood fill算法经典应用。但是写的时候还是漏洞百出。

遍历整个vector,遇到'0'跳过,遇到'1'则深入下去直接把包括这个'1'在内的往四个方向扩展的岛屿全部遍历完,并标记为'0'。这一趟下去表明发现了一个岛屿,我们在dfs之后cnt++。

在dfs中,我们先将当前位置标记,然后计算四个方向的坐标,坐标如果合法,我们便深入遍历,在下一层dfs中,将那个坐标标记为'0'........

相关推荐
Σίσυφος190015 分钟前
四元数 欧拉角 旋转矩阵
人工智能·算法·矩阵
shentuyu木木木(森)16 分钟前
单调队列 & 单调栈
数据结构·c++·算法·单调栈·单调队列
2501_9248787317 分钟前
矩阵跃动AI口播智能体:自研语音引擎破解数字人嘴型滞后、情绪扁平、方言失真——以粤语政务短视频为例
人工智能·深度优先·动态规划·政务
ghie909018 分钟前
基于MATLAB的指纹定位算法仿真实现
数据库·算法·matlab
沉睡的无敌雄狮19 分钟前
政务AI口播落地:矩阵跃动一体机100%本地化部署与零数据出域——某省大数据局3个月验证
大数据·人工智能·深度优先·动态规划·政务
熬了夜的程序员26 分钟前
【LeetCode】119. 杨辉三角 II
算法·leetcode·职场和发展
sali-tec40 分钟前
C# 基于OpenCv的视觉工作流-章24-SURF特征点
图像处理·人工智能·opencv·算法·计算机视觉
hillstream31 小时前
从这次xAI重组说开去--用类比的思维来理解
人工智能·算法·xai·elon.mask
菜鸡儿齐1 小时前
leetcode-最长连续序列
数据结构·算法·leetcode
寻寻觅觅☆1 小时前
东华OJ-基础题-120-顺序的分数(C++)
开发语言·c++·算法