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‘
最后更新于