-
Notifications
You must be signed in to change notification settings - Fork 892
/
problem_302.py
73 lines (56 loc) · 1.77 KB
/
problem_302.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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
from typing import Set
from random import sample
class Coord:
def __init__(self, x, y):
self.x = x
self.y = y
def __hash__(self):
return hash("{}-{}".format(self.x, self.y))
def __eq__(self, other):
return self.x == other.x and self.y == other.y
def __repr__(self):
return "[x={}, y={}]".format(self.x, self.y)
def explore_region(start: Coord, empty_spaces: Set, nrows: int, ncols: int):
if start not in empty_spaces:
return
empty_spaces.remove(start)
if start.x > 0:
explore_region(Coord(start.x - 1, start.y), empty_spaces, nrows, ncols)
if start.x < nrows - 1:
explore_region(Coord(start.x + 1, start.y), empty_spaces, nrows, ncols)
if start.y > 0:
explore_region(Coord(start.x, start.y - 1), empty_spaces, nrows, ncols)
if start.y < ncols - 1:
explore_region(Coord(start.x, start.y + 1), empty_spaces, nrows, ncols)
def get_region_count(text: str):
matrix = text.splitlines()
nrows, ncols = len(matrix), len(matrix[0])
for i in range(nrows):
matrix[i] = [x for x in matrix[i]]
empty_spaces = set()
for row in range(nrows):
for col in range(ncols):
if matrix[row][col] == " ":
empty_spaces.add(Coord(row, col))
regions = 0
while empty_spaces:
start = sample(empty_spaces, 1)[0]
explore_region(start, empty_spaces, nrows, ncols)
regions += 1
return regions
# Tests
matrix = \
"\\ /\n" + \
" \\ / \n" + \
" \\/ "
assert get_region_count(matrix) == 3
matrix = \
" /\n" + \
" \\ / \n" + \
" \\/ "
assert get_region_count(matrix) == 2
matrix = \
" /\n" + \
" \\ / \n" + \
" \\ "
assert get_region_count(matrix) == 1