-
Notifications
You must be signed in to change notification settings - Fork 65
/
Copy pathDFSGraphs.java
121 lines (106 loc) · 2.67 KB
/
DFSGraphs.java
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
/**
* Data-Structures-in-Java
* DFSGraphs.java
*/
package com.deepak.data.structures.Graph;
import java.util.List;
import java.util.Stack;
/**
* Depth First Search implemented for graphs
* <p> Algorithm :
* 1. Push the root element to Stack
* 2. Loop until stack is empty
* 3. Peek the node from the Stack
* 4. If the node has unvisited child nodes, get those nodes, push to Stack and mark as visited
* 5. If the node does not have any unvisited child node, pop it from the Stack.
* </p>
*
* @author Deepak
*/
public class DFSGraphs<T> {
/**
* Method to perform Depth First Search on a Graph
* @param root
* @param value
* @return {@link boolean}
*/
public static <T> boolean performDFS(DFSGraphNode<T> root, T value) {
if (root.getValue() == value) {
System.out.println("GraphNode found. Root = " + root);
return true; /* Value exists at root node */
}
/* Create a Stack. Set root as visited. Add the root to stack */
Stack<DFSGraphNode<T>> stack = new Stack<>();
root.setVisited(true);
stack.add(root);
/* Check if stack is not empty */
while (stack.peek() != null) {
/* Remove the first element from the stack */
DFSGraphNode<T> currentNode = stack.pop();
/* Check for all of the neighbors */
for (DFSGraphNode<T> graphNode : currentNode.getNeighbors()) {
/* If the neighbor is unvisited, mark it as visited and add to the stack */
if (!graphNode.isVisited()) {
graphNode.setVisited(true);
if (graphNode.getValue() == value) {
System.out.println("GraphNode found = " + graphNode);
}
stack.push(graphNode);
return true;
}
}
}
return false;
}
/**
* Static class DFSGraphNode
*
* @author Deepak
*
* @param <E>
*/
public static class DFSGraphNode<E> {
private E value;
private DFSGraphNode<E> next;
private List<DFSGraphNode<E>> neighbors;
private boolean visited;
/**
* Parameterized Constructor
* @param value
*/
public DFSGraphNode(E value) {
this.value = value;
}
/**
* Parameterized Constructor
* @param neighbors
*/
public DFSGraphNode(List<DFSGraphNode<E>> neighbors) {
this.neighbors = neighbors;
}
public E getValue() {
return value;
}
public void setValue(E value) {
this.value = value;
}
public DFSGraphNode<E> getNext() {
return next;
}
public void setNext(DFSGraphNode<E> next) {
this.next = next;
}
public List<DFSGraphNode<E>> getNeighbors() {
return neighbors;
}
public void setNeighbors(List<DFSGraphNode<E>> neighbors) {
this.neighbors = neighbors;
}
public boolean isVisited() {
return visited;
}
public void setVisited(boolean visited) {
this.visited = visited;
}
}
}