-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathFlood Fill.py
22 lines (18 loc) · 895 Bytes
/
Flood Fill.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
from typing import List
class Solution:
"""
Time: O(n*m)
Memory: O(n*m)
"""
def floodFill(self, image: List[List[int]], row: int, col: int, new_color: int) -> List[List[int]]:
if image[row][col] != new_color:
self.populate_color(image, row, col, new_color, image[row][col])
return image
@classmethod
def populate_color(cls, image: List[List[int]], row: int, col: int, new_color: int, old_color: int):
if 0 <= row < len(image) and 0 <= col < len(image[0]) and image[row][col] == old_color:
image[row][col] = new_color
cls.populate_color(image, row - 1, col, new_color, old_color)
cls.populate_color(image, row + 1, col, new_color, old_color)
cls.populate_color(image, row, col - 1, new_color, old_color)
cls.populate_color(image, row, col + 1, new_color, old_color)