Frage zur Tiefensuche

Luk10

Top Contributor
Grüße,

Ich habe einen Graphen und brauche eine Liste der Kanten die sich direkt zwischen knotenListe[start_index] und knotenListe[end_index] befinden. Dabei ist nicht wichtig ob es der kürzeste Weg ist, sondern nur, dass es ein direkter Weg ohne "Sackgassen" ist. Die Reihenfolge ist auch wichtig.

Mein Ansatz mit der Tiefensuche:

Java:
public void depthFirstSearch(int start_index, int end_index) {
		
		if (start_index != end_index) {
			
			for(int i = 0; i < nodelist.length; i++) {
				if (adjacencyMatrix[start_index][i] != null && !nodelist[i].isVisited()) {
					
					wantedNodes.add(nodelist[i]);
					wantedEdges.add(adjacencyMatrix[start_index][i]);
					nodelist[i].setVisited(true);
					
					depthFirstSearch(i, end_index);
					
				}
			}
		}
	}

Hierbei sollten alle Knoten in wantedNodes und alle Kanten ind wantedEdeges gespeichert. Leider funktioniert dass so nicht, da auch die Sackgassen mit in die Listen aufgenommen werden.

Kann mir jemand helfen das Problem zu lösen?

Danke,
-Luk10-
 

XHelp

Top Contributor
Deine Methode sollte aber auch irgendein Feedback geben (Rückgabewert), damit du weißt wann es eine Sackgasse war und wann nicht. Außerdem solltest du auch auf die möglichen Zyklen im Graphen achten.
 

Luk10

Top Contributor
Hm ... damit kann ich nicht so viel anfangen. Zyklen hat mein Graph keine und mit der Instanzvariablen "visited" werden Endlosschleifen eh abgefangen.

Kannst du das vielleicht ein bisschen konrekter schreiben? Kann mir darunter schon etwas vorstellen, aber nicht wie ich das umsetzten könnte.

Danke,
-Luk10-
 

XHelp

Top Contributor
Code:
boolean suchePfad(int aktuellerKnoten, int gesuchterKnoten) {
  if (aktuellerKnoten==gesuchterKnoten) {
    return true;
  } else {
    setzeBuschtStatus(aktuellerKnoten);
    if (keineKantenMehrZumUntersuchenVorhanden()) {
      return false;
    } else {
      for (int naechsterKnoten: alleZuUntersuchendeKnoten) {
        if (sechePfad(naechsterKnoten, gesuchterKnoten)) {
          markiere(aktuellerKnoten);
        }
      }
    }
  }
}
 

Luk10

Top Contributor
Hm, damit kann ich überhaupt nichts anfangen. Ich kann keine Überprüfung auf Kanten erkennen, und wie ich damit eine Liste von Kanten bzw Knoten bekommen, wie ich im 1. Post erklärt habe ist mir nicht klar ... Vielleicht bin ich auch einfach nur zu blöd den Trick zu erkennen, aber ausser dem Rückgabewert, ob der Knoten gefunden wurde, sehe ich da keine Lösung für mein Problem.

Danke,
-Luk10-
 

XHelp

Top Contributor
Probier es doch einfach aus. Müsste aber so ungefähr funktionieren. Den Pseudocode an dein Code anzupassen sind ja nur ein paar Minuten Arbeit.
 

Luk10

Top Contributor
Was macht:
Code:
keineKantenMehrZumUntersuchenVorhanden()
Ich habe die Kanten in keiner Liste gespeichert. Was soll das machen?

-Frage immernoch offen-

Danke,
-Luk10-
 

Luk10

Top Contributor
Man besucht keine Kanten sondern Knoten ... Aber das meinst du wahrscheinlich.

Nun gut ich werde das mal testen, obwohl mir der Ablauf des Algorithmus überhaupt nicht klat ist.
 

Luk10

Top Contributor
Gut:
Ich hab das jetzt so auf meine Situation angepasst:

Java:
	public boolean depthFirstSearch(int start_index, int end_index) {
		
		if (start_index == end_index) {
			return true;
		}
		else {
			nodelist[start_index].setVisited(true);
			
			boolean nodesleft = false;
			for (Node n : nodelist) {
				if (!n.isVisited()) {
					nodesleft = true;
				}
			}
			if (!nodesleft) {
				return false;
			}
			else {
				for (int i = 0; i < nodelist.length; i++) {
					if (depthFirstSearch(i, end_index)) {
						nodelist[i].setNextNode(nodelist[start_index]);
					}
				}
			}
		}
	}

1. Lässt sich nicht kompilieren, da nicht in allen Fällen ein wert zurückgegeben wird.
 

Luk10

Top Contributor
Java:
public class Graph {

	
	private Knoten[] knotenliste;
	private Kante[][] adjazenzMatrix;
	
	
	public Graph() {
		
		knotenliste = new Knoten[6];
		adjazenzMatrix = new Kante[6][6];
		
		baueGraph();
		
	}
	
	
	private void baueGraph() {
		
		knotenliste[0] = new Knoten();
		knotenliste[1] = new Knoten();
		knotenliste[2] = new Knoten();
		knotenliste[3] = new Knoten();
		knotenliste[4] = new Knoten();
		knotenliste[5] = new Knoten();
		
		adjazenzMatrix[0][1] = new Kante();
		adjazenzMatrix[1][0] = new Kante();
		
		adjazenzMatrix[1][2] = new Kante();
		adjazenzMatrix[2][1] = new Kante();
		
		adjazenzMatrix[2][3] = new Kante();
		adjazenzMatrix[3][2] = new Kante();
		
		adjazenzMatrix[3][4] = new Kante();
		adjazenzMatrix[4][3] = new Kante();
		
		//Verzweigung
		adjazenzMatrix[2][5] = new Kante();
		adjazenzMatrix[5][2] = new Kante();
		
	}
	
}

Graph sieht ca so aus:

Java:
0 - 1 - 2 - 3 - 4
        |          
        5


Java:
public class Knoten {

	
	private boolean besucht;
	private int liegtAufPfad; //int: Reihenfolge der Knoten
	
	
	public Knoten() {
		
		setBesucht(false);
		setLiegtAufPfad(-1);
		
	}
	//Getter und Setter


	public void setLiegtAufPfad(int liegtAufPfad) {
		this.liegtAufPfad = liegtAufPfad;
	}


	public int getLiegtAufPfad() {
		return liegtAufPfad;
	}


	public void setBesucht(boolean besucht) {
		this.besucht = besucht;
	}


	public boolean isBesucht() {
		return besucht;
	}

Java:
public class Kante {
	
	
	public Kante() {
		
	}

}

Jetzt brauche ich eine Methode, die mir einen Pfad zwischen zwei Knoten gibt, der keine Sackgassen hat! (Liste der Knoten oder Kanten auf dem Weg in Richtiger Reihenfolge)
Dazu könnte man z.B 1 als Start und 5 als Ziel nehmen

Danke,
-Luk10-
 
Zuletzt bearbeitet:

Luk10

Top Contributor
Eine Liste aller Kanten, die zwischen Knotenliste[start_index] und Knotenliste[end_index] liegen.
Somit ein Pfad durch den Graphen
Ohne Sackgassen, d.h. eine direkte Verbindung!

Wie lange der Weg ist, ist nicht von Bedeutung
 

Luk10

Top Contributor
Kann nochmal eine Idee von mir bieten, die aber noch nicht vollständig ist:


Java:
	public boolean depthFirstSearch(int start_index, int end_index) {
		
		if (start_index == end_index) {
			
			return true;
		
		}
		else {
			
			for (int i = 0; i < nodelist.length; i++) {
				if (adjacencyMatrix[start_index][i] != null && !nodelist[i].isVisited()) {
					
					if (depthFirstSearch(i, end_index) {
						nodelist[start_index].setNext(i);
					}
				}
			}
		}

Was mir Probleme bereitet ist, dass ich
a)
Code:
return depthFirstSearch(...)
aufrufen möchte um mir, bei der Abbruchfunktion das true Rückwerts durchzugeben und somit den Sackgassen-freien Weg

und

b) Auf
Code:
if(depthFirstSearch(...)
prüfen will, weil ich irgendwie auf den Wert prüfen muss


Wie kann man das machen ohne die Methode 2 Mal rekursiv aufzurufen und damit totalen Mist zu bauen?

-Luk10-
 

XHelp

Top Contributor
Ja, aber was ist, wenn es x verschiedene Pfade existieren?

Code:
   B - C - D - E
S -┤           ├-T
   F - G - H - I 
           |
           K - M

Was erwartest du bei Eingabe von S und T?
 

Marco13

Top Contributor
Nur schnell hingschrieben, ungefähr so könnt's gehen (backtracking quasi), könnte man geschickter machen.... Aber wichtig: Bei Zyklen haut's ihn so glaubich raus (vielleicht auch nicht ? Egal....)
Java:
import java.util.*;




public class GraphTest {

     public static void main(String args[])
     {
         GraphTest gt = new GraphTest();
         gt.depthFirstSearch(1,5);
     }

    public boolean depthFirstSearch(int start_index, int end_index)
    {
        List<Knoten> list = new ArrayList<Knoten>();
        depthFirstSearch(start_index, end_index, list);
        System.out.println("Result "+list);
        return true;
    }
    public boolean depthFirstSearch(int start_index, int end_index, List<Knoten> list)
    {
        System.out.println("From "+start_index+" to "+end_index+", currrent "+list);

        if (start_index == end_index) {

            return true;

        }
        else {

            for (int i = 0; i < knotenliste.length; i++) {
                if (adjazenzMatrix[start_index][i] != null && !knotenliste[i].isBesucht()) {

                    knotenliste[i].setBesucht(true);
                    list.add(knotenliste[i]);
                    boolean found = depthFirstSearch(i, end_index, list);
                    if (!found)
                    {
                        list.remove(knotenliste[i]);
                        knotenliste[i].setBesucht(false);
                    }
                    else
                    {
                        return true;
                    }
                }
            }
        }
        return false;
    }


    private Knoten[] knotenliste;
    private Kante[][] adjazenzMatrix;


    public GraphTest() {

        knotenliste = new Knoten[6];
        adjazenzMatrix = new Kante[6][6];

        baueGraph();

    }


    private void baueGraph() {

        knotenliste[0] = new Knoten(0);
        knotenliste[1] = new Knoten(1);
        knotenliste[2] = new Knoten(2);
        knotenliste[3] = new Knoten(3);
        knotenliste[4] = new Knoten(4);
        knotenliste[5] = new Knoten(5);

        adjazenzMatrix[0][1] = new Kante();
        adjazenzMatrix[1][0] = new Kante();

        adjazenzMatrix[1][2] = new Kante();
        adjazenzMatrix[2][1] = new Kante();

        adjazenzMatrix[2][3] = new Kante();
        adjazenzMatrix[3][2] = new Kante();

        adjazenzMatrix[3][4] = new Kante();
        adjazenzMatrix[4][3] = new Kante();

        //Verzweigung
        adjazenzMatrix[2][5] = new Kante();
        adjazenzMatrix[5][2] = new Kante();

    }

}





class Knoten {


    private boolean besucht;
    private int liegtAufPfad; //int: Reihenfolge der Knoten
    private int index;

    public Knoten(int index) {

        this.index = index;
        setBesucht(false);
        setLiegtAufPfad(-1);

    }
    //Getter und Setter


    public void setLiegtAufPfad(int liegtAufPfad) {
        this.liegtAufPfad = liegtAufPfad;
    }


    public int getLiegtAufPfad() {
        return liegtAufPfad;
    }


    public void setBesucht(boolean besucht) {
        this.besucht = besucht;
    }


    public boolean isBesucht() {
        return besucht;
    }

    public String toString()
    {
        return String.valueOf(index);
    }

}



class Kante {


    public Kante() {

    }

}
 

Luk10

Top Contributor
Wieso sind in deinem Beispiel, danke dafür, 4 Knoten in der Liste, obwohl nur 3 dir sind sollten?

Danke, Luk10

Edit: Genauer: 0 ist auch noch dabei ....
 
Zuletzt bearbeitet:

Marco13

Top Contributor
Oh ja, sorry, das hat noch nicht ganz gestimmt: Erstens muss man den startknoten auf "besucht" setzen, und zweitens was das "Rückgängigmachen" noch falsch
Java:
    public boolean depthFirstSearch(int start_index, int end_index)
    {
        List<Knoten> list = new ArrayList<Knoten>();
        list.add(knotenliste[start_index]);
        knotenliste[start_index].setBesucht(true);
        depthFirstSearch(start_index, end_index, list);
        System.out.println("Result "+list);
        return true;
    }
    public boolean depthFirstSearch(int start_index, int end_index, List<Knoten> list)
    {
        //System.out.println("From "+start_index+" to "+end_index+", currrent "+list);

        if (start_index == end_index) {

            //System.out.println("DONE");
            return true;

        }
        else {

            for (int i = 0; i < knotenliste.length; i++) {
                if (adjazenzMatrix[start_index][i] != null && !knotenliste[i].isBesucht()) {

                    knotenliste[i].setBesucht(true);
                    list.add(knotenliste[i]);
                    //System.out.println("Adding "+knotenliste[i]);
                    boolean found = depthFirstSearch(i, end_index, list);
                    if (found)
                    {
                        return true;
                    }
                    //System.out.println("Removing "+knotenliste[i]);
                    list.remove(knotenliste[i]);
                    knotenliste[i].setBesucht(false);
                }
            }
        }
        return false;
    }

Vermutlich sollte ich lieber doppelt so lange überlegen, und dann gleich was richtiges posten :oops: Aber ... nicht, dass dir noch langweilig wird :D

EDIT: Ich weiß nicht, ob das so stimmt. Vielleicht schaffe ich es, morgen nochmal ausführlicher zu überlegen und zu schauen.
 

Luk10

Top Contributor
Finally!

Es ist geschafft.
Vielen Dank, Marco13 und XHelp.

P.S Marco ich habs praktisch "gefixed". Funktioniert jetzt einwandfrei bei mir, vielen Dank
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Luk10 Frage zu Graph Tiefensuche Java Basics - Anfänger-Themen 4
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7
B Fachliche Frage bei Rechnungen Java Basics - Anfänger-Themen 16
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
B Frage zu Datenbank Design - Rechnungen, Angebote... und deren Positionen Java Basics - Anfänger-Themen 4
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 2
H Einfache Frage zur Punktnotation objektname.methode(wert) Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben