-
Notifications
You must be signed in to change notification settings - Fork 32
Expand file tree
/
Copy pathbfs.py
More file actions
26 lines (18 loc) · 657 Bytes
/
bfs.py
File metadata and controls
26 lines (18 loc) · 657 Bytes
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
# Python implementation of Breadth-First Search
import collections
def bfs(graph, root):
visited, queue = set(), collections.deque([root])
visited.add(root)
while queue:
# Dequeue a vertex from queue
vertex = queue.popleft()
print(str(vertex) + " ", end="")
# If not visited, mark it as visited, and enqueue it
for neighbour in graph[vertex]:
if neighbour not in visited:
visited.add(neighbour)
queue.append(neighbour)
if __name__ == '__main__':
graph = {0: [1, 2], 1: [2], 2: [3], 3: [1, 2]}
print("Breadth First Traversal: ")
bfs(graph, 0)