DATA STRUCTURE BREADTH FIRST TRAVERSAL DATA STRUCTURE & ALGORITHMS
What is Data Structure Breadth First Search (BFS)?
An algorithm which traverses the graph in a breadthward sequence is known as Breadth First Search or Breadth First Traversal. When dead end occurs, a queue is used to remember and go to the next vertex to start the search.
data:image/s3,"s3://crabby-images/bc0cf/bc0cff9d61d9c373874464bd62c938ab0eba1e1f" alt="Breadth First Traversal Breadth First Traversal"
As the image displays, BFS algorithm traverses from A to B to E to F first then to C and G lastly to D.
What are the rules employed by Data Structure Breadth First Search Algorithm?
BFS employs the following rules.
- Rule 1 − Visit the adjacent unvisited vertex. Mark it as visited. Display it. Insert it in a queue.
- Rule 2 − If no adjacent vertex is found, remove the first vertex from the queue.
- Rule 3 − Repeat Rule 1 and Rule 2 until the queue is empty.
What are the steps involved in Data Structure Breadth First Search?
The following are the steps:
Step 1 – Initialize the queue.
data:image/s3,"s3://crabby-images/3760b/3760bf97cd97c9c6653c9d46062e54e81f2965ad" alt="BFS Step One BFS Step One"
Step 2 - Start from visiting S (starting node), and mark it as visited.
data:image/s3,"s3://crabby-images/5b428/5b4289dfa3f3c27a314733076b6d266c5eee0a13" alt="BFS Step Two BFS Step Two"
Step 3 – An unvisited adjacent node is seen from S. Three nodes are available but choose alphabetically A, mark it as visited and enqueue it.
data:image/s3,"s3://crabby-images/e9e14/e9e14a96932f622c426e2ec7f55f44ff0efc807c" alt="BFS Step Three BFS Step Three"
Step 4 - Next, the unvisited adjacent node from S is B. Mark it as visited and enqueue it.
data:image/s3,"s3://crabby-images/2fa02/2fa025c356bb240ae179d34afc7eeeabf2e5c61a" alt="BFS Step Four BFS Step Four"
Step 5 - Next, the unvisited adjacent node from S is C. Mark it as visited and enqueue it.
data:image/s3,"s3://crabby-images/385d6/385d6ac4d178724d29cfbf29335ade37d07e7f8b" alt="BFS Step Five BFS Step Five"
Step 6 - Now, S is left with no unvisited adjacent nodes. So, dequeue and find A.
data:image/s3,"s3://crabby-images/ceade/ceadeb8cca46f18460d2f989c0ba92d0bed5e969" alt="BFS Step Six BFS Step Six"
Step 7 - From A now D is unvisited adjacent node. Mark it as visited and enqueue it.
data:image/s3,"s3://crabby-images/15065/1506512aee69fb4c3c3718836fb606ab0c011c58" alt="BFS Step Seven BFS Step Seven"
Now, no unmarked or unvisited nodes are left. But keep on dequeuing to get all the unvisited nodes, as the queue gets emptied, the program gets over.
No comments:
Post a Comment