DATA STRUCTURE - DEPTH FIRST TRAVERSAL DATA STRUCTURE & ALGORITHMS
What is Data Structure Depth First Traversal?
A graph is traversed in a depthward motion by using a stack to go to the next vertex, by an algorithm known as Depth First Search (DFS) algorithm.
data:image/s3,"s3://crabby-images/b3c28/b3c289efc2194263e5d445cf7e40f558b1bf2350" alt="Depth First Traversal Depth First Traversal"
DFS algorithm traverses from A to B to C to D first then to E, then to F and lastly to G.
What are the rules employed by DFS algorithm?
The following are the rules employed by the DFS algorithm:
- Rule 1 − Visit the adjacent unvisited vertex. Mark it as visited. Display it. Push it in a stack.
- Rule 2 − If no adjacent vertex is found, pop up a vertex from the stack. (It will pop up all the vertices from the stack, which do not have adjacent vertices.)
- Rule 3 − Repeat Rule 1 and Rule 2 until the stack is empty.
What are the steps in Data Structure Depth First Traversal?
The following are the steps:
Step 1 - Initialize the stack.
data:image/s3,"s3://crabby-images/80301/80301dd85eb4de5d68273f12ee197c81b4b4f984" alt="DFS Step one DFS Step one"
Step 2 - Mark S as visited and put it onto the stack. Any unvisited adjacent node is explored from S. Out of the three nodes, pick any one, preferable take in alphabetical order.
data:image/s3,"s3://crabby-images/4b46e/4b46e6626589f29e9f51e71fddb0d292fea15518" alt="DFS Step Two DFS Step Two"
Step 3 - Mark A as visited and put it onto the stack. Any unvisited adjacent node from A are explored. Both S and D are adjacent to A but the concern is about the unvisited nodes only.
data:image/s3,"s3://crabby-images/43d9e/43d9e0c8d4bbffe479120966f8cb350c12ebee1e" alt="DFS Step Three DFS Step Three"
Step 4 - Visit D and mark it as visited and put onto the stack. Here, both B and C nodes are there, which are adjacent to D and both are unvisited. However, choose in an alphabetical order.
data:image/s3,"s3://crabby-images/5a3d7/5a3d72f637d31f55be342128acfd4efb0c458e0e" alt="DFS Step Four DFS Step Four"
Step 5 - Choose B, mark it as visited and put onto the stack. Here B does not have any unvisited adjacent node. So, pop B from the stack.
data:image/s3,"s3://crabby-images/2cdf7/2cdf7d293c74c442a931494b275902f3f0c75f77" alt="DFS Step Five DFS Step Five"
Step 6 - Check the stack top for return to the previous node and check if it has any unvisited nodes. Here, D is found to be on the top of the stack.
data:image/s3,"s3://crabby-images/c8c8c/c8c8cf38bc979ca3311fad3c1596f048574cab5e" alt="DFS Step Six DFS Step Six"
Step 7 - Only unvisited adjacent node is from D is C now. So visit C, mark it as visited and put it onto the stack.
data:image/s3,"s3://crabby-images/ba8b8/ba8b8aa286c838158c8d7355c9e7dbdadfcd56e3" alt="DFS Step Seven DFS Step Seven"
As C does not have any unvisited adjacent node so the stack is kept popping until a node with an unvisited adjacent node is found. Here, it is none and hence keep popping until stack is empty.
No comments:
Post a Comment