Methoden Wegsuche in einem Graph

S

SchokoPanzer

Mitglied
Nunja, es geht primär darum alle Wege in von einem Startknoten zu dem besagten Endknoten zu finden. Ich hab hier meinen rekursiven Ansatz, nur irgendwie funktioniert der nicht so ganz richtig wie er soll.

Naja zum Code selbst
Der Graph ist gerichtet
Kanten sind über eine Hashmap<T, HashSet<T>> implementiert
Die Idee ist über eine ForEach Schleife alle verfügbaren Zielknoten vom jeweiligen Standpunkt aus zu abzulaufen und halt cycle's zu vermeiden. Erfolgreich gefundene Pfade sollen in einer List<List<T> gespeichert werden.

Mein Problem ist, dass er a) immer nur einen Pfad findet und b) ist es nicht immer der gleiche Oo
Ab und an hängt er auch mal nen Knoten an den Pfad, obwohl keine Kante dahin führt.

Hat irgendwer ne Idee was falsch gelaufen sein könnte?
Ich vermute ich mach einen Denkfehler bei der Rekursion, aber hab keine Ahnung ob ich damit richtig liege und wie ichs anders machen könnte.

Wäre Dankbar für jedwede Hilfe =)


[Java]
private void RecursiveAllPathSearch(T CurrentNode, T endNode, ArrayList<T> path){
if (path.contains(CurrentNode)){ // cycle's abfangen
path = null;
}

else {
if (CurrentNode == endNode){ //erfolgreichen path speichern
path.add(CurrentNode);
paths.add(path);
}
else {
path.add(CurrentNode); // weiter "forschen" -> rekursiv
HashSet<T> NextNodes = edges.get(CurrentNode);
for(T elements : NextNodes){
RecursiveAllPathSearch(elements, endNode, path);
}
}

}
}
[Java]
 
H

Herr K.

Gast
Hallo,

ohne mir den Code näher angeschaut zu haben, fällt sofort ein Fehler auf:

Java:
f (path.contains(CurrentNode)){ // cycle's abfangen
path = null;
}

else {
if (CurrentNode == endNode){ //erfolgreichen path speichern
path.add(CurrentNode);

Da kannst Du gar nicht mehr als einen Weg finden, denn der Endknoten gehört zu jedem erfolgreichen Weg, Du verwirfst aber jeden Knoten, den Du schon kennst. Hier ist es (wie so oft) wichtig, dass Du die Reihenfolge beachtest.

Bei rekursiven Aufrufen sollte man immer mit dem Rekursionsanker anfangen, in Deinem Fall Endet die Rekursion in zwei Fällen:
  1. Du hast den Endknoten gefunden
  2. Es gibt keine Kindknoten mehr
 
S

SchokoPanzer

Mitglied
Wie implimentier ich das denn dann am sinnvollsten?

Schon richtig, die Methode soll aufhören sich in dieser Instanz aufzurufen wenn sie das Ziel hat, oder es nicht mehr weiter geht (Ende oder Cycle)

Die For Each soll in dem Fall garantieren dass für jeden verfügbaren Pfad vom derzeitigen Knoten weg, die methode mit den jeweiligen werten neu aufgerufen wird.

Für mich bedeutet dass, dass die Methode eigentlich weitermacht solange nicht alle For Each abgeklappert wurden ( Sinn einer For Each Schleife ), nur dass erfolgreiche Pfade nicht rekursiv weiter geführt werden, aber die restlichen sollten es doch eigentlich oder Oo?
 
S

SchokoPanzer

Mitglied
Ja hab ich, ich brauch aber alle Pfade zum Ziel ausgegeben und nicht nur den kürzesten

ich brauch einen Algorithmus der alle Pfade zum Ziel findet, und mir diese Ausgibt ( am sinnvollsten in einer List of Lists )
Jeder Pfad soll durch eine Liste dargestellt werden

Wenn der Algorithmus nicht weitermachen, weil er sonst Cyclen würde, oder halt es keine Kindknoten mehr gibt, soll der bis dato erstellte Pfad einfach verworfen werden


Mein Problem ist dass mein Algorithmus komische Dinge tut und ich absolut keine Idee hab woran das liegt
 
X

XHelp

Top Contributor
Warum baust du dir nicht einfach ein paar Debugausgaben rein und schaust, wie das ganze wirklich abläuft?
Du könntest deine Methode etwas umschreiben, damit die wirklich was zurückliefern. Ungetesteter Pseudocode:
Java:
List<List<T>> findPaths(T from, T to, List<T> currentPath) {
  List<List<T>> results = new ArrayList<List<T>>();
  if (currentPath.contains(from)) {
    return results;
  }
  if (from.equals(to)) {
    results.add(currentPath);
    return results;
  }
  currentPath.add(from);
  for (T child: nodeList) {
    results.addAll(findPaths(child, to, currentPath));
  }
  return results;
}
 
S

SchokoPanzer

Mitglied
So es ist geschafft =)

Nach etlichen Debugausgaben und mit dem Gedanken bei dem von Mr K. angesprochenen fehlerhaften Rekursionsanker
wanderte nun endlich die hand zum kopf, der mund ging auf und ich hab mich ewig für meine blödheit verflucht :)

ändert man

Java:
if (CurrentPath.contains(FromNode)){...}

in

Java:
if (CurrentPath.contains(FromNode) && FromNode != ToNode){ ... }

fängt der auf einmal an sinnvolle Pfade auszuspucken ^^

lg
Schoko

und vielen Dank für die Denkanstöße
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Labyrith Rekursive Wegsuche Java Basics - Anfänger-Themen 4
U Muster in einem Array erkennen Java Basics - Anfänger-Themen 8
Y Wie greift man auf die Knoten in einem Binärbaum zu? Java Basics - Anfänger-Themen 5
rafi072001 Lesen aus einem Excel File Java Basics - Anfänger-Themen 10
Y Wie kann man überprüfen, ob bei einem Print Befehl tatsächlich etwas geprintet wurde? Java Basics - Anfänger-Themen 4
J Lösungen zu einem Lückentext finden Java Basics - Anfänger-Themen 0
Z Char Array an zufälligen stellen mit einem "x" füllen. Java Basics - Anfänger-Themen 4
L Alle Ziele in einem Raster abknallen Java Basics - Anfänger-Themen 17
T Auf einem Schachbrett bewegen programmieren Java Basics - Anfänger-Themen 2
F JMenuItem Kann nicht nach einem String benannt werden... Java Basics - Anfänger-Themen 11
H 3 Comparatoren zu einem zusammenfassen - Chaining... Java Basics - Anfänger-Themen 15
N LocalTime einem Objekt zuweisen Java Basics - Anfänger-Themen 2
B Berechnung der Position von Kinderelemente von einem Elternknoten Java Basics - Anfänger-Themen 23
N Länge eines Arrays in einem Objekt testen Java Basics - Anfänger-Themen 51
B Alle Links in einem Text suchen und ersetzen mit einem neuen Link Java Basics - Anfänger-Themen 18
J Elemente in einem 2D-Array summieren Java Basics - Anfänger-Themen 6
J String aus einem Array entfernen Java Basics - Anfänger-Themen 10
L Breadth-First Search statt einem Pfad, alle Pfade herausfinden Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
J Ich brauche Hilfe bei einem Code (Variablen speichern) Java Basics - Anfänger-Themen 29
P Arraylist zu einem Array bringen mit Verschachtelung Java Basics - Anfänger-Themen 11
S Ersetzen eines Asterix in einem String Java Basics - Anfänger-Themen 8
X Nach einem Bruch testen ob es eine ganze Zahl ist Java Basics - Anfänger-Themen 6
M Von einem JTextField Doublewerte entgegennehmen Java Basics - Anfänger-Themen 2
M Ist es möglich, das größte und zweitgrößte element in einem Array mit nur einer Schleife ausfindig zu machen ? Java Basics - Anfänger-Themen 19
H Objekt aus einem Array löschen Java Basics - Anfänger-Themen 1
F Aufgabe: Abstand von einem Punkt zu einem anderen Punkt Java Basics - Anfänger-Themen 10
H Befehle in einem Menü aktivieren Java Basics - Anfänger-Themen 1
L Anzahl der Elemente key in einem Array mit log(N) Laufzeit Java Basics - Anfänger-Themen 4
FelixN RegEx aus einem String als String-Array zurückgeben Java Basics - Anfänger-Themen 8
B Werte aus einem Unterprogramm in ein Array schreiben Java Basics - Anfänger-Themen 2
L Nur Bestimmte Werte aus einem Array in ein anderes Speichern Java Basics - Anfänger-Themen 11
J erstes Vorkommen eines Chars aus einem String entfernen Java Basics - Anfänger-Themen 3
F Summe in einem Array bestimmen Java Basics - Anfänger-Themen 3
D Alle Möglichkeiten, n-Anzahl aus Elementen aus einem Array zu wählen, ausgeben? Java Basics - Anfänger-Themen 23
B Warum können super() und this() nicht gemeinsam in einem Konstruktor verwendet werden? Java Basics - Anfänger-Themen 7
B String zu einem bestehenden String hinzufügen Java Basics - Anfänger-Themen 9
F Sektglasaufgabe aus einem Programmierbuch Java Basics - Anfänger-Themen 7
B Name von Verzeichnis bekommen - Files von einem Ordner auslesen Java Basics - Anfänger-Themen 4
topi relativer Pfad in einem Runnable JAR file Java Basics - Anfänger-Themen 12
B Liste von Tagen generieren ab einem bestimmten Datum und Endedatum Java Basics - Anfänger-Themen 4
O Lambda Ausdrücke in einem Comparator Java Basics - Anfänger-Themen 4
D Werte aus einem BinärBaum in einem Array speichern Java Basics - Anfänger-Themen 1
E Zahlen von einem Array mit zahlen von zweitem Array vergleichen Java Basics - Anfänger-Themen 27
J Wie kann ich z.B. einem int-Wert einen String-Wert zuweisen? Java Basics - Anfänger-Themen 2
R Value von einem JSON-Objekt ausgeben Java Basics - Anfänger-Themen 4
S Was bewirkt ganz genau throw hinter einem Funktionsnamen? Java Basics - Anfänger-Themen 14
G Überprüfen ob alle Ziffern von 1-9 in einem Integer vorhanden sind Java Basics - Anfänger-Themen 6
F Mehrere Exceptions in einem Catch-Block abfangen Java Basics - Anfänger-Themen 12
N Zeichen in einem Textfeld zählen und hinterlegen Java Basics - Anfänger-Themen 6
W 2 JPanel in einem JFrame Java Basics - Anfänger-Themen 4
O String von vorne nach hinten an einem Zeichen Java Basics - Anfänger-Themen 10
F Buchstaben in einem String vertauschen (Ohne replace) Java Basics - Anfänger-Themen 10
O findRoot Methode schreiben in einem Intervall Java Basics - Anfänger-Themen 31
O Primzahl rekursiv mit einem Wert ohne i, wie? Java Basics - Anfänger-Themen 6
S Fragen zu einem Rechentrainer Java Basics - Anfänger-Themen 2
S Schiffe versenken - Zufallszahlen in einem Array Java Basics - Anfänger-Themen 6
J Datentypen Komm in einem Android Buch mit Java nicht weiter... Java Basics - Anfänger-Themen 7
B Prüfen, ob es schon einen Termin gibt in einem Zeitraum Java Basics - Anfänger-Themen 5
R Vererbung werte von einem Objekt aus ein anderes übertragen Java Basics - Anfänger-Themen 7
Dimax Leerzeilen aus einem String entfernen Java Basics - Anfänger-Themen 61
N Abfragen eines Textes aus einem JTextField in Java, Funktion, CardLayout, Java Basics - Anfänger-Themen 2
K In einem Case gefüllte Arraylist in einer anderen Case ausgeben Java Basics - Anfänger-Themen 2
J Mehrere paintComponenten in einem Programm Java Basics - Anfänger-Themen 0
A In einem String alle Eigennamen zählen Java Basics - Anfänger-Themen 6
F Mehrere Buttons mit einem ActionListener abdecken Java Basics - Anfänger-Themen 24
T Auslagern von Methoden bei einem JFrame Java Basics - Anfänger-Themen 6
Dilara_K Abstand zwischen den Doppelwerten in einem Array herausfinden Java Basics - Anfänger-Themen 20
V Einem JButton anweisungen geben Java Basics - Anfänger-Themen 4
S Problem mit einem rekursivem FloodFill Algorithmus Java Basics - Anfänger-Themen 62
S Sequenz von Zahlen bei einem Stack möglich oder nicht möglich? Java Basics - Anfänger-Themen 5
M Methoden Zwei Methoden in einem Program laufen lassen...aber wie? Java Basics - Anfänger-Themen 2
T Schauen ob eine Ziffer in einem String-Array häufiger vorkommt Java Basics - Anfänger-Themen 8
A Harshad Zahlen sollen in einem Intervall ausgegeben werden Java Basics - Anfänger-Themen 8
P Input/Output Bestimmte Anzahl von Werten in einem Array an Methode übergeben Java Basics - Anfänger-Themen 2
H Stringanzeige in einem Label Java Basics - Anfänger-Themen 2
das_leon Gesamtes Programm in einem Fenster Java Basics - Anfänger-Themen 1
Aprendiendo [JAVA-Syntax] (int... variable) bei einem Konstruktor Java Basics - Anfänger-Themen 8
N OOP 2 versch. Modi in einem Objekt de/aktivieren Java Basics - Anfänger-Themen 10
J Hintergrund bei einem Schachfeld Java Basics - Anfänger-Themen 1
N Methoden vorherigen Wert in einem Array lieferen Java Basics - Anfänger-Themen 8
P Aus einem Array zwei Arrays machen Java Basics - Anfänger-Themen 3
M Einzelne Pixel in einem Bild auslesen und bearbeiten Java Basics - Anfänger-Themen 1
S JOptionPane mit Schleife in einem Ausgabefenster Java Basics - Anfänger-Themen 4
H Compiler-Fehler Out of Bunce Exception bei einem Char Java Basics - Anfänger-Themen 6
C Variablen von einem JFrame in einen anderen übertragen Java Basics - Anfänger-Themen 3
D Input/Output Array in einem String mit einem Trennzeichen verbinden Java Basics - Anfänger-Themen 17
M 2 Stellen in einem Array vergleichen und bei übereinstimmen eine davon ersetzen Java Basics - Anfänger-Themen 1
Arif OOP Die Bindung zwischen einem äußeren und einem inneren Objekt Java Basics - Anfänger-Themen 2
V Elemente aus einem Array mit null überschreiben Java Basics - Anfänger-Themen 4
J Erste Schritte Problem mit einer bool-Variable in einem Bot-Programm Java Basics - Anfänger-Themen 1
sourcecorn Werte aus einem File lesen Java Basics - Anfänger-Themen 6
C Methoden Methode zu einem Binären Suchbaum Java Basics - Anfänger-Themen 8
K Compiler-Fehler Durchschnitt einer Spalte in einem 2D-Array Java Basics - Anfänger-Themen 1
A .txt Datei in einem Array speichern Java Basics - Anfänger-Themen 1
J Durchschnitt jeder Zeile und und Spalte in einem 2D Arrays berechnen Java Basics - Anfänger-Themen 6
H Suche in einem Text Java Basics - Anfänger-Themen 17
H Leere Eingabe in einem array Java Basics - Anfänger-Themen 11
A Problem beim Deklarieren von einem BOOLEAN Java Basics - Anfänger-Themen 4
B seltenes Vorkommen eines Integers in einem Array Java Basics - Anfänger-Themen 13

Ähnliche Java Themen

Anzeige

Neue Themen


Oben