-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgraph2.py
94 lines (81 loc) · 2.49 KB
/
graph2.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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
class Graph:
vertices = {}
time = 0
def __init__(self, vertices={}):
self.vertices = vertices
def add_vertex(self, vertex):
if isinstance(vertex, Vertex) and vertex not in self.vertices:
self.vertices[vertex.name] = vertex
return True
else:
return False
def add_edge(self, u, v):
vertices = self.vertices
if u in vertices and v in vertices:
for key, value in vertices.items():
if key == u:
value.add_neighbour(v)
if key == v:
value.add_neighbour(u)
return True
else:
return False
def print_graph(self):
for key in set(arr(self.vertices.keys())):
print(key + str(self.vertices[key].neighbours) + " " + str(self.vertices[key].discovery) + "/" + str(self.vertices[key].finish))
def _dfs(self, vertex):
global time
vertex.discovery = time
vertex.color = 'red'
time += 1
for v in vertex.neighbours:
if self.vertices[v].color == 'black':
self._dfs(self.vertices[v])
vertex.color = 'blue'
vertex.finish = time
time += 1
def dfs(self, vertex):
global time
time = 1
self._dfs1(vertex)
def _dfs1(self,vertex):
global time
vertex.color = 'red'
vertex.discovery = time
for v in vertex.neighbours:
if self.vertices[v].color == 'black':
self._dfs1(self.vertices[v])
vertex.color = 'blue'
vertex.finish = time
time += 1
class Vertex:
def __init__(self, name):
self.name = name
self.neighbours = arr()
self.discovery = 0
self.finish = 0
self.color = 'black'
def add_neighbour(self, v):
nset = set(self.neighbours)
if v not in nset:
self.neighbours.append(v)
self.neighbours.sort()
'''
if __name__ != "__main__":
graph = Graph()
for i in range(ord('A'), ord('H')):
graph.add_vertex(Vertex(chr(i)))
edges = ['AB', 'BF', 'CG', 'DE', 'DH', 'EH', 'FG', 'FI', 'FJ', 'GJ', 'HI']
for edge in edges:
graph.add_edge(edge[:1], edge[1:])
graph.dfs(graph.vertices['A'])
graph.print_graph()'''
if __name__ == "__main__":
arr = []
for i in range(0,5):
temp = list()
for j in range(0, 5):
temp.append(j)
arr.append(temp)
print(arr)
print(arr[1][4])