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'........

相关推荐
智驱力人工智能7 小时前
景区节假日车流实时预警平台 从拥堵治理到体验升级的工程实践 车流量检测 城市路口车流量信号优化方案 学校周边车流量安全分析方案
人工智能·opencv·算法·安全·yolo·边缘计算
MicroTech20257 小时前
微算法科技(NASDAQ :MLGO)抗量子攻击区块链共识机制:通过量子纠缠态优化节点验证流程,降低计算复杂度
科技·算法·区块链
pp起床7 小时前
贪心算法 | part01
算法·贪心算法
梵刹古音7 小时前
【C语言】 字符数组与多维数组
c语言·数据结构·算法
咩咩不吃草7 小时前
机器学习不平衡数据处理三招:k折交叉验证、下采样与过采样实战
人工智能·算法·机器学习·下采样·过采样·k折交叉验证
weixin_452159557 小时前
模板编译期条件分支
开发语言·c++·算法
多恩Stone7 小时前
【3DV 进阶-11】Trellis.2 数据处理与训练流程图
人工智能·pytorch·python·算法·3d·aigc·流程图
老师用之于民7 小时前
【DAY20】数据结构基础:(算法)排序、折半查找的函数实现
数据结构·算法·排序算法
一起养小猫7 小时前
Flutter for OpenHarmony 进阶:推箱子游戏算法与关卡设计深度解析
算法·flutter·游戏
民乐团扒谱机7 小时前
【微实验】Zhang-Suen 快速并行细化算法与MATLAB实现
人工智能·学习·算法·计算机视觉·数学建模·matlab