深さ優先探索を使用して、有向加重グラフのパスを特定し、サイクルに属するノードを再検討し、移動した合計距離またはソースノードからの停止に基づいてカットオフ条件を設定しています。
私が理解しているように、再帰では、深さ優先探索に明示的なスタック構造は必要ありません。したがって、明示的なスタックを使用せずに、以下のコードをさらに単純化できるかどうか疑問に思いました。
public class DFSonWeightedDirectedGraph {
private static final String START = "A";
private static final String END = "E";
private int pathLength = 0;
private int stops = 0;
public static void main(String[] args) {
//this is a directed weighted graph
WeightedDirectedGraph graph = new WeightedDirectedGraph();
graph.addEdge("A", "B", 15);
graph.addEdge("A", "D", 15);
graph.addEdge("A", "E", 27);
//(...) more edges added
Stack<String> visited = new Stack<String>();
visited.push(START);
new DFSonWeightedDirectedGraph().depthFirst(graph, visited);
}
private void depthFirst(WeightedDirectedGraph graph, Stack<String> visited) {
Collection<Map.Entry<String, Integer>> tree_of_children
= graph.get_tree_of_children(visited.peek());
for (Map.Entry<String, Integer> child : tree_of_children) {
if(pathLength + child.getValue()>= 20){
continue;
}
visited.push(child.getKey());
pathLength += child.getValue();
stops += 1;
if (child.getKey().equals(END)) {
printPath(visited);
}
depthFirst(graph, visited);
visited.pop();
pathLength -= child.getValue();
stops -= 1;
}
}
private void printPath(Stack<String> visited) {
for (String node : visited) {
System.out.print(node);
System.out.print(" ");
}
System.out.println("[path length: "+pathLength +
" stops made: " + stops +"]");
}
}
ただし、明示的なスタック構造を持たない他の再帰的な実装では、通常、すでにアクセスしたノードを白、灰色、または黒に色付けして考慮します。それで、再訪が許可され、パスを記録する必要がある私の場合、明示的なスタックは絶対に必要ですか?より簡単な代替案の提案をありがとう。