Java で深さ優先検索アルゴリズムを実装しようとしています。このメソッドが無限ループに入る理由は何ですか? ありがとう。
public Node search(Graph graph, String nodeName, int ID) {
//Get the root node
Node root = graph.getRoot();
Stack<Node> stack = new Stack<Node>();
//Add the root to the stack
stack.push(root);
while(!stack.isEmpty())
{
Node n = stack.pop();
//Check to see if node n is the requested node
if(n.getName().equals(nodeName))
{
//Found
return n;
}else
{
//Create an array of the leaf nodes to node n
Node[] children = n.getNeighbours();
for(int i =0; i<children.length; i++)
{
//Add the leaf nodes to the stack
stack.push(children[i]);
System.out.println(stack.peek());
}
}
}
//Not found so return null
return null;
}