岛屿数量 -- 二维矩阵的dfs算法

岛屿数量

又被称为 FloodFill 算法

python 复制代码
class NumIslands:
    """
    floodFill 算法
    https://leetcode.cn/problems/number-of-islands/
    """
    def solution(self, grid: List[List[str]]) -> int:
        res = 0
        m, n = len(grid), len(grid[0])
        for i in range(m):
            for j in range(n):
                if grid[i][j] == '1':
                    res += 1
                    self.dfs_matrix(grid, i, j)

        return res

    def dfs_matrix(self, grid, i, j):
        m, n = len(grid), len(grid[0])

        # 跳出递归条件
        if i < 0 or i >= m or j < 0 or j >= n:
            return

        if grid[i][j] == '0':
            return
        grid[i][j] = '0'
        self.dfs_matrix(grid, i - 1, j)  # 上
        self.dfs_matrix(grid, i + 1, j)  # 下
        self.dfs_matrix(grid, i, j - 1)  # 左
        self.dfs_matrix(grid, i, j + 1)  # 右
        
相关推荐
孟大本事要学习11 分钟前
算法第15天:继续二叉树|前序递归+回溯与前序递归的场景总结、最大二叉树、合并二叉树、二叉搜索树中的搜索、验证二叉搜索树
算法
GalaxyPokemon24 分钟前
LeetCode - 76. 最小覆盖子串
运维·服务器·数据结构·算法·leetcode
手握风云-40 分钟前
动态规划算法的欢乐密码(二):路径问题
算法·动态规划
Raven100861 小时前
L1G2-OpenCompass 评测书生大模型实践
算法
NAGNIP2 小时前
RAG信息检索-如何让模型找到‘对的知识’
算法
电院工程师4 小时前
轻量级密码算法CHAM的python实现
python·嵌入式硬件·算法·安全·密码学
@老蝴10 小时前
C语言 — 通讯录模拟实现
c语言·开发语言·算法
L-ololois10 小时前
【AI】模型vs算法(以自动驾驶为例)
人工智能·算法·自动驾驶
安全系统学习12 小时前
网络安全之RCE简单分析
开发语言·python·算法·安全·web安全
GEEK零零七13 小时前
Leetcode 3299. 连续子序列的和
算法·leetcode·动态规划