The Graph Theory | Breadth First Search
Breadth first search is one of the most basic algorithms for searching a graph. Many other algorithms like Prim’s minimum spanning tree and Dijkstra’s single source shortest path algorithm are derived from breadth first search algorithm.
Within this blog post we will be
- Giving a brief introduction to bread-first search
- Write a pseudocode for the same
- Explain it via example
- Analyze the complexity
- Write a c++ program related to the same
Introduction To Breadth First Search
Suppose we are given a graph G = (V,E) and a distinguished source vertex S. Breadth first search explored the edges of G to find all vertices that are reachable from s. It computes the distance from s to each reachable vertex.
For every vertex v reachable from s, the simple path containing source vertex v and source vertex s is the shortest path from s to v.
Breadth first search is names so because it first looks at the nodes directly corresponding to the base node, then it go deep down at other nodes within the graph. Basically just like in a tree, we have parent node as the source node and the child nodes as the nodes directly corresponding to the base node. First the root node is parsed, then the corresponding nodes to the root node and so on.
Pseudocode of breadth first search
BFS(G,s) | |
for each vertex in graph (u) except source vertex (s) | |
u.color = white | |
u.d = infinte | |
u.a = nil | |
s.color = gray | |
s.d = 0 | |
s.a = nil | |
Q = 0 //create an empty queue | |
Enqueue(Q) | |
while Q!=null | |
u = Dequeue(Q) | |
for each v in adjacent[u] | |
if v.color = white | |
v.color = gray | |
v.d = v.d + 1 | |
v.a = u | |
Enqueue(Q,v) | |
u.color = Black |
The pseudocode is simple.
First we are going to parse all vertex of the graph except for the source vertex and change the color of the node to white, since the nodes haven’t been parsed so distance will be zero and no ancestor node is present.
Next we are going to change the color of the source vertex to gray and since it’s the initial node we change the distance to 0 and it has no ancestor nodes.
Now we will take an empty queue and start adding the gray color elements to the queue. Gray colored elements are those which are currently being parsed. Once we have added the gray color elements to the queue we will take the adjacent element from the adjacency list of the gray element and add them to the queue. Since queue works on FIFO principle, the element is inserted from the last position but the first element inserted will be taken out of the queue.
Now we are going to parse the queue till the time it’s not empty and dequeue the queue. Once the adjacent elements are being parsed, we will change the color of the element to gray, increase the distance by one and enqueue the queue. Once the element of the queue is parsed we will change of the color of the element to be dequeued to black. Once all the elements of the graph has been parsed we will have all nodes as black.
This approach is explained via example
The adjacency list for the graph is shown here
The operations of BFS on undirected graph are shown below:
Analysis of BFS algorithm
We know that all the elements of the graph will be parsed only once or atmost once. The operation to enqueue and dequeue takes O(1) time, so total time devoted by queue is only O(V). The algorithm scans the adjacency list of each vertex only when the vertex is dequeued, it scans each adjacency list at most once. Since the sum of the lengths of all the adjacency list is θ(E), the total time spent in scanning adjacency lists is O(E). So the total running time of BFS procedure is O(V+E).
That’s all folks for now! We discussed a very important algorithm called breadth first search, wrote a pseudocode for the same, explained it via example and analyzed its complexity. Within our next tutorial, we are going to look at another important algorithm called Depth First Search.