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

相关推荐
Ulyanov12 小时前
《从质点到位姿:基于Python与PyVista的导弹制导控制全栈仿真》: 刚体觉醒——6-DOF刚体动力学、四元数与全姿态解算
开发语言·人工智能·python·算法·系统仿真·雷达电子对抗仿真
Dillon Dong12 小时前
机侧同步定子电压环的PI整定:从“对齐三个量“到“闭环四步法“
算法·变流器·风电控制·dfig
Languorous.13 小时前
C++数据结构进阶|图(Graph)详解:从存储到面试高频算法实战
算法
我头发还没掉光~13 小时前
P4147 玉蟾宫
数据结构·c++·算法
江汉似年13 小时前
强化学习中的 On-policy 与 Off-policy 全面解析
人工智能·深度学习·算法·rl
code bean13 小时前
【LangChain 】 自定义解析器实战指南:从原理到 10 个业务场景落地
算法·langchain
念恒1230614 小时前
基础IO(一切皆文件)
linux·c语言·c++·算法
d111111111d14 小时前
MQTT+STM32+云平台+AT命令的编写
服务器·笔记·stm32·单片机·嵌入式硬件·算法
铁皮哥14 小时前
【力扣题解】LeetCode 25. K 个一组翻转链表
java·数据结构·windows·python·算法·leetcode·链表
洛水水15 小时前
【力扣100题】29. 对称二叉树
算法·leetcode·职场和发展