-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathCount Sub Islands.py
41 lines (33 loc) · 1.14 KB
/
Count Sub Islands.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
from typing import List
class Solution:
"""
Time: O(n^2)
Memory: O(n^2)
"""
LAND = 1
WATER = 0
def countSubIslands(self, grid1: List[List[int]], grid2: List[List[int]]) -> int:
m, n = len(grid1), len(grid1[0])
for i in range(m):
for j in range(n):
if grid2[i][j] == self.LAND and grid1[i][j] == self.WATER:
self.sink_island(i, j, grid2)
islands = 0
for i in range(m):
for j in range(n):
if grid2[i][j] == self.LAND:
self.sink_island(i, j, grid2)
islands += 1
return islands
@classmethod
def sink_island(cls, row: int, col: int, grid: List[List[int]]):
if grid[row][col] == cls.LAND:
grid[row][col] = cls.WATER
if row > 0:
cls.sink_island(row - 1, col, grid)
if row < len(grid) - 1:
cls.sink_island(row + 1, col, grid)
if col < len(grid[0]) - 1:
cls.sink_island(row, col + 1, grid)
if col > 0:
cls.sink_island(row, col - 1, grid)