200. 岛屿的个数
解法一: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)二、并查集
优化
最后更新于