-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathBreathFirstSearch.py
More file actions
32 lines (28 loc) · 942 Bytes
/
BreathFirstSearch.py
File metadata and controls
32 lines (28 loc) · 942 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
27
28
29
30
31
32
#coding:utf-8
"""
------------------------------------------------
@File Name : BreathFirstSearch
@Function :
@Author : Minux
@Date : 2018/10/27
@Revised Date : 2018/10/27
------------------------------------------------
"""
from algorithm_and_data_structure.BFS.Vertex import Vertex
from queue import Queue
class BreadthFirstSearch:
def bfs(self, root):
if not isinstance(root, Vertex):
raise Exception('Type Error')
else:
_queue = Queue()
root.visited = True
_queue.put(root)
while not _queue.empty():
actual_v = _queue.get()
print(actual_v.data, end=' - ')
# 利用了队列FIFO的性质
for v in actual_v.get_neighbour():
if ~v.visited:
v.visited = True
_queue.put(v)