Tiefensuche

Diese Seite verwendet Cookies. Durch die Nutzung unserer Seite erklären Sie sich damit einverstanden, dass wir Cookies setzen. Weitere Informationen

  • Hier wird der Algorithmus zur Tiefensuche erklärt. Außerdem gibt es eine Beispielimplementation in Java.

    Ablauf

    Zuerst wird ein Startknoten u ausgewählt. Von diesem Knoten aus wird nun die erste Kante (u,v) betrachtet und getestet, ob der gegenüberliegende Knoten v schon entdeckt wurde bzw. das gesuchte Element ist. Ist dies noch nicht der Fall, so wird rekursiv für diesen Knoten die Tiefensuche aufgerufen, wodurch wieder der erste Nachfolger dieses Knotens expandiert wird. Diese Art der Suche wird solange fortgesetzt, bis das gesuchte Element entweder gefunden wurde oder die Suche bei einer Senke im Graph angekommen ist und somit keine weiteren Nachfolgeknoten mehr untersuchen kann. An dieser Stelle kehrt der Algorithmus nun zum zuletzt expandierten Knoten u zurück und untersucht den nächsten Nachfolger des Knotens. Sollte es hier keine weiteren Nachfolger mehr geben, geht der Algorithmus wieder Schritt für Schritt zum jeweiligen Vorgänger zurück und versucht es dort erneut.

    Algorithmus

    1. Bestimme den Knoten an dem die Suche beginnen soll
    2. Expandiere den Knoten und speichere alle Nachfolger in einem Stack
    3. Rufe rekursiv für jeden der Knoten in dem Stack DFS (depth first search oder Tiefensuche) auf
    Falls der Stack leer sein sollte, tue nichts
    Falls das gesuchte Element gefunden worden sein sollte, brich die Suche ab und liefere ein Ergebnis

    Beispiel: Java

    Quellcode

    1. void tiefensuche(Graph g) {
    2. Set<String> visited = new TreeSet<String>();
    3. for (Iterator<String> it = g.nodeIterator(); it.hasNext(); ) {
    4. String n = it.next();
    5. if (!visited.contains(n))
    6. tiefensucheRek(g, n, visited);
    7. }
    8. }
    9. void tiefensucheRek(Graph g, String node, Set<String> visited) {
    10. visited.add(node);
    11. action(node);
    12. for (Iterator<String> it = g.edgeIterator(node); it.hasNext(); ) {
    13. String expanded = it.next();
    14. if (!visited.contains(expanded)) {
    15. visited.add(expanded);
    16. tiefensucheRek(g, expanded, visited);
    17. }
    18. }
    19. }
    Alles anzeigen

    35.157 mal gelesen