Depth-first search







Depth-first search (DFS) is an algorithm for traversing or searching tree or graph data structures. The algorithm starts at the root node (selecting some arbitrary node as the root in the case of a graph) and explores as far as possible along each branch before backtracking.
Algorithm[edit]
The basic idea of DFS is to start from the root (or any arbitrary node) and mark the node and move to an adjacent unmarked node and continue this process until there is no unmarked adjacent node. Then backtrack and check for other unmarked nodes and traverse them. Finally, print the nodes in the path.
Pseudocode[edit]
The pseudocode for DFS is as follows:
Recursive DFS:
procedure DFS(G, v) is
label v as discovered
for all directed edges from v to w that are in G.adjacentEdges(v) do
if vertex w is not labeled as discovered then
recursively call DFS(G, w)Iterative DFS:
procedure DFS-iterative(G, v) is
let S be a stack
S.push(v)
while S is not empty do
v = S.pop()
if v is not labeled as discovered then
label v as discovered
for all edges from v to w in G.adjacentEdges(v) do
S.push(w)Applications[edit]
DFS is used in various applications, including:
- Topological sorting
- Finding connected components
- Pathfinding
- Solving puzzles with only one solution, such as mazes
Properties[edit]
- DFS can be implemented using recursion or using a stack.
- The time complexity of DFS is O(V + E), where V is the number of vertices and E is the number of edges.
- The space complexity of DFS is O(V) in the worst case.
Related Algorithms[edit]
See Also[edit]
Related Pages[edit]
- Graph (discrete mathematics)
- Tree (data structure)
- Breadth-first search
- Topological sorting
- Pathfinding

This article is a algorithms or data structures-related stub. You can help WikiMD by expanding it!
Ad. Transform your life with W8MD's
GLP-1 weight loss injections special from $29.99


W8MD Medical Weight Loss, Sleep and Medspa offers physician-supervised medical weight loss programs: NYC medical weight loss Philadelphia medical weight loss
Affordable GLP-1 Weight Loss ShotsAffordable GLP-1 Weight Loss Shots
Budget GLP-1 injections NYC (insurance & self-pay options) Popular treatments:
- Semaglutide starting from $29.99/week
- Tirzepatide starting from $45.00/week
✔ Most insurances accepted for visits ✔ Prior authorization support when eligible
Start your physician weight loss NYC journey today:
📍 NYC: Brooklyn weight loss center 📍 Philadelphia: Philadelphia weight loss center
📞 Call: 718-946-5500 (NYC) | 215-676-2334 (Philadelphia)
Tags: Affordable GLP1 weight loss NYC, Wegovy NYC, Zepbound NYC, Philadelphia medical weight loss
|
WikiMD Medical Encyclopedia |
Medical Disclaimer: WikiMD is not a substitute for professional medical advice. The information on WikiMD is provided as an information resource only, may be incorrect, outdated or misleading, and is not to be used or relied on for any diagnostic or treatment purposes. Please consult your health care provider before making any healthcare decisions or for guidance about a specific medical condition. WikiMD expressly disclaims responsibility, and shall have no liability, for any damages, loss, injury, or liability whatsoever suffered as a result of your reliance on the information contained in this site. By visiting this site you agree to the foregoing terms and conditions, which may from time to time be changed or supplemented by WikiMD. If you do not agree to the foregoing terms and conditions, you should not enter or use this site. See full disclaimer.
Credits:Most images are courtesy of Wikimedia commons, and templates, categories Wikipedia, licensed under CC BY SA or similar.
Translate this page: - East Asian
中文,
日本,
한국어,
South Asian
हिन्दी,
தமிழ்,
తెలుగు,
Urdu,
ಕನ್ನಡ,
Southeast Asian
Indonesian,
Vietnamese,
Thai,
မြန်မာဘာသာ,
বাংলা
European
español,
Deutsch,
français,
Greek,
português do Brasil,
polski,
română,
русский,
Nederlands,
norsk,
svenska,
suomi,
Italian
Middle Eastern & African
عربى,
Turkish,
Persian,
Hebrew,
Afrikaans,
isiZulu,
Kiswahili,
Other
Bulgarian,
Hungarian,
Czech,
Swedish,
മലയാളം,
मराठी,
ਪੰਜਾਬੀ,
ગુજરાતી,
Portuguese,
Ukrainian