-
Notifications
You must be signed in to change notification settings - Fork 3
/
dfs_traversal.py
77 lines (60 loc) · 1.82 KB
/
dfs_traversal.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
# Python program to print DFS
# traversal for complete graph
from collections import defaultdict
# This class represents a
# directed graph using adjacency
# list representation
class Graph:
# Constructor
def __init__(self):
# default dictionary to store graph
self.graph = defaultdict(list)
# function to add an edge to graph
def addEdge(self, u, v):
self.graph[u].append(v)
# A function used by DFS
def DFSUtil(self, v, visited):
# Mark the current node as visited and print it
visited.add(v)
print(v, end=" ")
# Recur for all the vertices adjacent to
# this vertex
for neighbour in self.graph[v]:
if neighbour not in visited:
self.DFSUtil(neighbour, visited)
# The function to do DFS traversal. It uses
# recursive DFSUtil()
def DFS(self):
# Create a set to store all visited vertices
visited = set()
# Call the recursive helper function to print
# DFS traversal starting from all vertices one
# by one
for vertex in list(self.graph):
if vertex not in visited:
self.DFSUtil(vertex, visited)
def DFS_STACK(self):
visited = [False for vertex in list(self.graph)]
stack = []
stack.append(0)
while stack:
s = stack.pop(-1)
if not visited[s]:
print(s, end=" ")
visited[s] = True
for vertex in list(self.graph):
if not visited[vertex]:
stack.append(vertex)
# Driver code
# Create a graph given in the above diagram
g = Graph()
g.addEdge(0, 1)
g.addEdge(0, 2)
g.addEdge(1, 2)
g.addEdge(2, 0)
g.addEdge(2, 3)
g.addEdge(3, 3)
print("Following is Depth First Traversal")
g.DFS()
print()
g.DFS_STACK()