200. 岛屿的个数

https://leetcode-cn.com/problems/number-of-islands/

解法一:dfs

思路很直接,遍历棋盘,遇到‘1’就dfs,把访问过的地方置‘0’。统计dfs次数即可

class Solution:
    def numIslands(self, grid: List[List[str]]) -> int:
        count = 0  #统计岛屿数
        #遍历棋盘
        for i in range(len(grid)):
            for j in range(len(grid[0])):
                #遇到‘1’就调用递归dfs搜索,岛屿数+1
                if grid[i][j] == '1':  
                    count += 1
                    self.dfs(grid, i, j)
                    #递归完再加也可
                    #count += 1
        return count
    
    #深度优先遍历所有‘1’,并置零
    def dfs(self, grid, i, j):
        #特别要注意边界,除了越界,还有‘0’也要返回,否则会无限重复访问
        if i < 0 or i >= len(grid) or j < 0 or j >= len(grid[0]) or grid[i][j] == '0':
            return
        grid[i][j] = '0'    #访问该岛屿,并标记为0
        #上下左右
        self.dfs(grid, i-1, j)
        self.dfs(grid, i+1, j)
        self.dfs(grid, i, j-1)
        self.dfs(grid, i, j+1)

二、并查集

并查集初始化为m*n规模(每个点都是一个根),此处略作修改,连通分量个数为‘1’的数量,‘0’不计入。

遍历二维网格,遇到‘1’就尝试将上下左右的1连通,最后统计连通分量数

优化

遍历时,若当前节点为1,使用后可以置0以减少重复计算

130. 被围绕的区域不同,那里求并查集之后还需要用到’O‘的位置信息,因此使用后不能置’X‘

最后更新于