-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path#785 isBipartite.py
52 lines (46 loc) · 1.44 KB
/
#785 isBipartite.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
# Solution 1: Not using a flag
class Solution:
def isBipartite(self, graph: List[List[int]]) -> bool:
color = {}
for i in range(len(graph)):
if i not in color:
color[i] = 0
if self.search(i, color, graph):
return False
return True
def search(self, start: int, color: dict, graph: List[List[int]]) -> bool:
for n in graph[start]:
if n not in color:
color[n] = not color[start]
if self.search(n, color, graph):
return True
else:
if color[n] == color[start]:
return True
return False
# Solution 2: Using a flag
# class Solution:
# def __init__(self):
# self.f = True
#
# def isBipartite(self, graph: List[List[int]]) -> bool:
# color = [0 for _ in range(len(graph))]
# visited = set()
#
# for i in range(len(graph)):
# if i not in visited:
# self.search(i, color, graph, visited)
#
# return self.f
#
# def search(self, start: int, color: list, graph: List[List[int]], visited: set) -> None:
# visited.add(start)
#
# for n in graph[start]:
# if n not in visited:
# color[n] = not color[start]
#
# self.search(n, color, graph, visited)
#
# if color[n] == color[start]:
# self.f = False