-
Notifications
You must be signed in to change notification settings - Fork 121
/
Copy pathDFS.py
30 lines (26 loc) · 848 Bytes
/
DFS.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
class Graph:
def __init__(self,nodes):
self.graph=[]
for i in range(0,nodes):
self.graph.append([])
def addedge(self,initial,final):
(self.graph[initial]).append(final)
# Graph is the adjacency list
def DFS(self,root):
visited = []
dfs = []
# Using Stack Implementation
for i in range(0,len(self.graph)):
visited.append(False)
dfs.append(root)
visited[root] = True
while len(dfs)!=0:
t = dfs.pop(-1)
# Can change this part to your own convenience
print(t)
# Endblock
if len(self.graph[t])>0:
for i in self.graph[t]:
if visited[i] == False:
dfs.append(i)
visited[i] = True