Tiefensuche Probleme - Der "Rücksprung"

Status
Nicht offen für weitere Antworten.

schlachtrufe

Mitglied
hi, ich habe eine adjazentenmatrix gegeben und möchte davon alle nachfolger verfolgen, bis zu einem knoten, welcher keine nachfolger hat. (der graph hat keinen kreis).
das habe ich nun hinbekommen, aber danach soll ja zu dem vorrigen knoten (von dem man gekomemn ist) zurück kehren und weiter suchen.
also z.b. so eine matrix:
01001
00101
00000
00100
00010

ich hab da irgendetwas mit stack gelesen, dass da die sprungmarken gespeichert werden. verstehe aber nicht, woher die rekursion weis, dass sie an der stelle wieder reingehen soll, wovon sie raus gesprungen ist, bzw wie man das in java schreibt.

code beispiel:
Code:
void suche_rek(int ii) {
    int i;
    int j=0;
    //"durchspringt" die ersten beiden Zeilen
    for (i = ii; j < matrix.length; j++) {    
    	
      if (g[i][j] == 1)
        suche_rek(j);
    } //for endet in der 3. Zeile, weil es keine 1 sen gibt
    
    int[] speicher  = new int[k];
    speicher[i] = k; //das i in speicher[i] entspricht der zeilennummer
    System.out.println(i + " - " + k);
    k--;
    rekursion(i); //ist wohl falsch
  } //rekursion


also, dieser algorithmus springt in der 3. zeile aus der for schleife, gibt dem array speicher eine nummer und soll dann eigentlich in der vorrigen zeile bei der ersten 1 (bzw an dem punkt welcher verlassen wurde) wieder einsteigen und gucken, ob es noch eine 1 gibt. etc... für alle knoten dann halt.
 

Marco13

Top Contributor
Öhm - das macht sie schon automatisch. (Wäre auch schlimm, wenn nicht :wink: ). Eine Test-Funktion kann da zum Verständnis helfen

Code:
class RekTest
{
    public static void main(String args[])
    {
        rek(0, "");
    }


    public static void rek(int n, String indent)
    {
        System.out.println(indent+"Betrete Ebene "+n);
        if (n==4)
        {
            System.out.println(indent+"Fertig, n ist vier! Keine rekursiven Aufrufe mehr!");
            return;
        }
        else
        {
            System.out.println(indent+"Bin in Ebene "+n+" und mache Rekursion auf Ebene "+(n+1));
            rek(n+1, indent+"    ");
            System.out.println(indent+"Der Aufruf von Ebene "+(n+1)+" ist fertig, jetzt bin ich wieder in Ebene "+n);
        }
        System.out.println(indent+"Verlasse Ebene "+n);
    }
}

Was wohl nicht funktionieren wird ist, den Array in jedem Aufruf neu zu erstellen. Wenn der 'speicher' den Weg speichern soll, wird das nicht funktionieren, weil ja nicht nur EIN Weg gespeichert wird, sondern ein ganzer Baum. Beschreib' evlt. mal genauer, was das werden soll....
 

schlachtrufe

Mitglied
vielen dank für das gute beispiel. also wird der rücksprung mittels return gemacht?

wie meinst du das mit dem neuerstellen des arrays?

also das ist topologisches sortieren mit tiefensuche, an einem ungewichteten, gerichteten, kreisfreien graphen.
man sucht von einem knoten, ob es einen nachfolger gibt und wenn ja, dann springe zum nächsten knoten und suche dort wieder nach einem nachfolger, solange bis zu einem knoten, welcher keine nachfolger hat
-> dieser bekomtm die höchste wertigkeit.
dann muss zu dem vorrigen knoten zurück gesprungen werden, an der stelle wo man rausgesprungen ist, und weitersuchen, ob es noch nachbarn gibt.

also an der adjazentenmatrix da oben erklärt: (ich fang mal bei 1 an zu zählen)
- untersucht knoten 1 auf nachfolger -> knoten 2 ist nachfolger (da steht ja eine 1)
- sprung zu knoten 2 und beginne suche am anfang, knoten 3 ist nachfolger
- 3 hat keine nachfolger (alles 0), bekommt wertigkeit 5
- springe zurück, also zu knoten 2 an stelle 3 und suche weiter -> knoten 5 ist nachfolger
- sprung zu 5
- sprung zu 4
- sprung zu 3 und erkenne, dass knoten 3 schon eine nummer hat, also gehe wieder zurück zu 4 und wertigkeit-1
- zurückspringen zu 5, erkenne 4 hat nummer -> wertigkeit-1
- rücksprung 2, alle nachbarn haben nummer
- rücksprung 1 alle nachbarn haben nummer, fertig
damit ergibt sich für die knoten 1 2 3 4 5 folgende wertigkeit (in reihenfolge der knotennummer): 1 2 5 4 3
 

Marco13

Top Contributor
Der "Rücksprung" wird gemacht, indem "return" aufgerufen wird, ODER wenn die Funktion bis zum Ende abgearbeitet ist (man könnte, wenn man's drauf anlegt, auch noch ein "return" in die letzte Zeile der Funktion schreiben :wink: )

Du hast dort einen durchlauf beschrieben ... :? Ich hab' nochmal bei Wikipedia nachgesehen - der dort beschriebene Algorithmus ist der, den ich gelernt hatte ... das mit der "Wertigkeit" musss man jetzt erstmal auf das Problem übertragen... Naja, das ist deine Aufgabe. Nur zu dem 'speicher': Vermutlich wäre es Sinnvoll, den Array entweder in der Klasse zu speichern, oder an die Funktion mit zu übergeben. Es darf ja nicht bei jedem Neuen Aufruf der Funktion ein neuer Array erstellt werden, sondern es muss (von Anfang bis Ende) immer derSELBE Array sein.

BTW: So eine Zeile wie
- sprung zu 3 und erkenne, dass knoten 3 schon eine nummer hat, also gehe wieder zurück zu 4 und wertigkeit-1
ist ein bißchen diffizil - und vielleicht liegt auch genau dort das Problem (!???!) Jedenfalls muss man dort ja bei Knoten 4 erkennen, dass man bei Knoten 3 eine bestimmte Wertigkeit gefunden hatte -- darum als Tipp: Es kann gut sein, dass die Funktion einen 'int' zurückgeben muss, der eine Wertigkeit beschreibt (bin da zwar nicht 100% sicher, es sieht stark danach aus)
 

schlachtrufe

Mitglied
ja das array speicher muss ausserhalb der funktion initialisiert werden.
das mit der wertigkeit hab ich ja am anfang nicht erwähnt, weil es mir erstmal darum nicht ging und ansonsten hät ich ja sagen können programmiert mal und schickt mir den vollständigen code :)

das mit dem rücksprung hab ich durch einen nikolaus algorithmus jetzt besser verstanden. warum das genau funktioniert zwar noch nicht richtig, aber da müsste man sich das mit dem stack nochmal angucken?

ja das problem liegt daran, zu erkennen das ein knoten schon eine wertigkeit abbekommen hat.
da weis ich nicht wie ich das machen soll. eine if überprüfung irgendwohin (vor dem rekursiven aufruf irgendwas überprüfen?) ?
bzw ich mach doch dann ein return nach der wertzuweisung?
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
Q Tiefensuche Graph -> Schulprojekt Java Basics - Anfänger-Themen 1
F Graph Tiefensuche Methode Java Basics - Anfänger-Themen 7
U Best Practice Graphen Tiefensuche Klassifizierung von Kanten "B","C","F" Java Basics - Anfänger-Themen 2
4 Stack over flow bei rekursiver Tiefensuche Java Basics - Anfänger-Themen 5
E Erste Schritte brauche hilfe zum verstehen einer Klasse(Tiefensuche) Java Basics - Anfänger-Themen 17
A Tiefensuche in Graph Java Basics - Anfänger-Themen 4
Luk10 Frage zur Tiefensuche Java Basics - Anfänger-Themen 20
Luk10 Frage zu Graph Tiefensuche Java Basics - Anfänger-Themen 4
kirchrath Wegpunkt wird nicht zur History einer Tiefensuche hinzugefügt Java Basics - Anfänger-Themen 2
K Tiefensuche Java Basics - Anfänger-Themen 2
H Tiefensuche im binären Baum Java Basics - Anfänger-Themen 2
G Mit der Tiefensuche alle Wege finden Java Basics - Anfänger-Themen 2
S [EDIT] Tiefensuche / Depth-First-Search / Greedy Algorithmus Java Basics - Anfänger-Themen 6
M Graphen (Tiefensuche) Java Basics - Anfänger-Themen 2
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
C Probleme mit Byte konvertieren nach int Java Basics - Anfänger-Themen 10
P Probleme mit NetBeans: Wie lässt sich jar. Datei an einem MacBook öffnen Java Basics - Anfänger-Themen 21
I Projekte in IDE untereinander sharen / Probleme beim Build Java Basics - Anfänger-Themen 8
MiMa Probleme mit Datentyp long ?? Java Basics - Anfänger-Themen 2
T Probleme beim Import eines Git-Repos Java Basics - Anfänger-Themen 2
Jxhnny.lpz TicTacToe Spiel vs Computer. (Probleme) Java Basics - Anfänger-Themen 7
B Quiz mit RMI Probleme mit RMI start Java Basics - Anfänger-Themen 4
httprt Probleme bei dem erstellen von leveln in meinem Spiel Java Basics - Anfänger-Themen 2
berserkerdq2 Habe eine Klasse, welche public ist, diese hat eine public Methode, die nicht static ist. Wenn ich nun versuche aufzurufen Probleme? Java Basics - Anfänger-Themen 8
V Probleme Guessing Game Java Basics - Anfänger-Themen 8
hebein PDF Ausdruck auf Drucker - Probleme mit Format Java Basics - Anfänger-Themen 17
R JMenu/JMenuItem Probleme Java Basics - Anfänger-Themen 2
B Static vs non static und Probleme daraus Java Basics - Anfänger-Themen 13
J Probleme mit dem Debugger Java Basics - Anfänger-Themen 4
I Probleme mit OutputStream - Datei lässt sich nicht öffnen Java Basics - Anfänger-Themen 4
J Probleme mit Kompilierung Java Basics - Anfänger-Themen 11
B Probleme mit Zugriff auf Dateisystem Windows 10 ( jFileChooser) Java Basics - Anfänger-Themen 17
W Objekte über Scanner Input; ToString Probleme... Java Basics - Anfänger-Themen 4
C Probleme mit paintComponent Java Basics - Anfänger-Themen 13
P Probleme mit JUnit-Tests, es kommt was anderes raus als bei manuellen Tests Java Basics - Anfänger-Themen 5
E JavaFX Editor Probleme mit der Zwischenablage Java Basics - Anfänger-Themen 12
C Probleme mit dem Erstellen und Importieren von Packages Java Basics - Anfänger-Themen 6
3 OOP erste Versuche, OOP zu verstehen. Probleme mit gettern und settern Java Basics - Anfänger-Themen 4
R Erste Schritte Probleme bei 2D Spielfeld, mit einzufügender "Person" Java Basics - Anfänger-Themen 5
P Probleme bei der Installation von JavaFX Java Basics - Anfänger-Themen 3
S Mehrere Probleme im Code Java Basics - Anfänger-Themen 7
D Probleme mit JFrame und der Größe Java Basics - Anfänger-Themen 8
Dimax String Probleme Java Basics - Anfänger-Themen 12
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
Splayfer Java Array Probleme Java Basics - Anfänger-Themen 3
J Probleme bei IllegalArgumentException "werfen". Java Basics - Anfänger-Themen 1
K Probleme bei der Ausgabe - komme nicht weiter :/ Java Basics - Anfänger-Themen 15
X Probleme im Umgang mit PriorityQueue Java Basics - Anfänger-Themen 75
D Probleme mit dem Windowbuilder und JComboBox Java Basics - Anfänger-Themen 2
M Regex Probleme (mal wieder) Java Basics - Anfänger-Themen 3
tom.j85 TicTacToe - probleme beim Casten Java Basics - Anfänger-Themen 6
J Probleme mit Vererbung Java Basics - Anfänger-Themen 4
X Probleme mit Übungsaufgaben zu Zahlentypen Java Basics - Anfänger-Themen 4
G Probleme bei Aufgabe Java Basics - Anfänger-Themen 12
P Erste Schritte Probleme mit dem Programmieren Java Basics - Anfänger-Themen 12
B Probleme bei einer Aufgabe Java Basics - Anfänger-Themen 19
Franzi1001 Probleme mit Eclipse Java Basics - Anfänger-Themen 7
T Probleme bei Installation von JDK Java Basics - Anfänger-Themen 2
C Probleme mit String-Vergleich Java Basics - Anfänger-Themen 4
C Probleme bei Regex Java Basics - Anfänger-Themen 9
V Probleme mit Arrays Java Basics - Anfänger-Themen 8
D Kleine Probleme mit Split-Befehlen Java Basics - Anfänger-Themen 5
T Probleme mit Strings Java Basics - Anfänger-Themen 6
G Probleme bei Frame aufgaben Java Basics - Anfänger-Themen 6
N Probleme mit dem ActionListener Java Basics - Anfänger-Themen 4
D Probleme beim Kompelieren mache ich etwas falsch ? Java Basics - Anfänger-Themen 3
L Probleme mit Java Java Basics - Anfänger-Themen 3
S Probleme mit abspielen einer .wav Datei Java Basics - Anfänger-Themen 2
J Probleme bei der Umwandlung einer Farbe von Hex zu RGB Java Basics - Anfänger-Themen 8
K Probleme beim Programm schreiben - Lesen von Dateiinhalten -zaehlen von Wörtern/ Buchstaben Java Basics - Anfänger-Themen 4
M Probleme beim aktualisieren eines JPanels Java Basics - Anfänger-Themen 7
J Probleme beim Array ausgeben Java Basics - Anfänger-Themen 4
M Probleme bei rekursiver Zuordnung Java Basics - Anfänger-Themen 1
I Probleme mit 2 dimensionale Arrays Java Basics - Anfänger-Themen 3
H Best Practice View probleme Java Basics - Anfänger-Themen 2
B Probleme mit Kreisberechnung Java Basics - Anfänger-Themen 15
E Probleme mit Scanner Java Basics - Anfänger-Themen 4
J Eclipse Export Probleme Java Basics - Anfänger-Themen 25
M Probleme beim verwenden von Packages Java Basics - Anfänger-Themen 6
D Probleme mit der Übergabe einer BorderPane Java Basics - Anfänger-Themen 2
J Interface Probleme bei der Implementierung Java Basics - Anfänger-Themen 1
BlueFox Tabelle in der Konsole ausgeben - Probleme Java Basics - Anfänger-Themen 1
G Methoden Probleme beim Methodenaufruf Java Basics - Anfänger-Themen 2
V Klassen ObjectInputStream ->ReadObject Probleme Java Basics - Anfänger-Themen 5
P Probleme mit der Do-Schleife Java Basics - Anfänger-Themen 2
F Erste Schritte Compiling Probleme Java Basics - Anfänger-Themen 13
S Neuling und Probleme bei Schulaufgabe Java Basics - Anfänger-Themen 5
J Anfänger: ActionListener und ProcessBuilder machen Probleme Java Basics - Anfänger-Themen 6
S Erste Schritte 2D Grafik Probleme mit KeyListener. Java Basics - Anfänger-Themen 18
M Array mit eigenem Datentyp probleme beim übergeben Java Basics - Anfänger-Themen 6
M Probleme mit Eclipse Java Basics - Anfänger-Themen 20
G Probleme beim casten von double zu int Java Basics - Anfänger-Themen 3
E 2 Probleme - Datum & private finale Variablen Java Basics - Anfänger-Themen 5
S Compiler-Fehler javac hat Probleme mit Paketen unter OSX Java Basics - Anfänger-Themen 2
J Probleme beim schreiben von Dateien Java Basics - Anfänger-Themen 5
B Variablen Probleme mit Eclipse Java Basics - Anfänger-Themen 6
H Mouse- und KeyListener Probleme? Java Basics - Anfänger-Themen 5
A Probleme beim zykl. aktulisieren von Daten in JTable Java Basics - Anfänger-Themen 3
I Probleme bei Verzeichnissanalyse Java Basics - Anfänger-Themen 12

Ähnliche Java Themen

Neue Themen


Oben