Hilfe bei einer rekursiven Methode

beta20

Top Contributor
Hallo,

ich möchte gerne eine rekursive Methode erstellen.
Das Ziel ist es von einem "Element" alle Kinder zu bekommen. Also sprich alle Elemente, die miteinander verknüpft sind.
Hierzu habe ich eine Liste von den Connections von einem Diagrammodell. Nun gehe ich diese Connections durch und suche die Verbindung.

Das heißt, dass ich mit einem "Element" in the Methode starte, und dann immer wieder darüber iteriere, bis es keine Kinder mehr gibt...
Allerdings scheint, dass der Methodenaufruf noch nicht so ganz passt. Ebenfalls muss irgendwie noch ein Check sein, wenn es kein Kind mehr gibt, weil sonst gebe ich ja wieder eine leere Liste zurück?

Java:
    /**
     * Findet alle ChildElement von einem Element / alle Connections
     *
     */
    public List<Element> findAllChildFromElement(DefaultDiagramModel diagramModel, Element startElement) {

        LOGGER.info("START findAllChildFromElement");

        List<Element> elementList = new ArrayList<Element>();

        for (EndPoint endPoint : startElement.getEndPoints()) {

            // Alle Connections durchgehen, und prüfen, wer diesen Endpoint verwenden als Target
            for (Connection connection : diagramModel.getConnections()) {
                               
                if (connection.getSource().equals(endPoint)) {
                    Element e = findElementByEndpoint(diagramModel, connection.getTarget());
                    elementList.add(e);
                   
                    // Methode nochmals aufrufen
                    elementList = findAllChildFromElement(diagramModel, e);
                }
            }
        }

        LOGGER.info("END findAllChildFromElement");
        return elementList;
    }

Ich verwende diese Klassen:

Kann mir hier jemand helfen?
 

MoxxiManagarm

Top Contributor
Also wenn ich dich richtig verstehe, dann willst du alle zusammenhängende Elemente in der Liste haben. Das ist vergleichbar mit einem Graphen. Belese dich gerne etwas in Graphentheorie. Aus meiner Sicht fehlt dir die Abfrage, welchen Knoten - also welches Element - du bereits besucht hast. Nur wenn du e noch nicht besucht hast fügst (d.h. e existiert nicht in elementList) fügst du e zu elementList hinzu und untersuchst e.

Außerdem hast du mehrere rekursive Aufrufe (durch die Schleife), welche du aber nicht verknüpfst. elementList = findAllChildFromElement(diagramModel, e); sollte vermutlich keine Zuweisung sein, sondern ein addAll
 
Zuletzt bearbeitet:

beta20

Top Contributor
Hier mal ein Beispiel:
Element "startElement" (im Methodenkopf) ist das rote Element:
Was ich nun möchte ist, dass ich alle grünen Elementen bekommen

 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Hilfe bei Fehlerfindung einer rekursiven Methode Java Basics - Anfänger-Themen 2
S Hilfe zu einer Aufgabe Java Basics - Anfänger-Themen 5
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
D Hilfe bei einer Aufgabe mit for-Schleife Java Basics - Anfänger-Themen 6
Robert_Klaus Hamster java Simulation Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 5
S Hilfe bei Programmierung einer Hotelabrechnung Java Basics - Anfänger-Themen 5
jonathanpizza Hilfe bei einer Übungsaufgabe Java Basics - Anfänger-Themen 6
jonathanpizza Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 5
JD_1998 Random Array sortieren mit Hilfe einer Methode Java Basics - Anfänger-Themen 4
J Brauche Hilfe bei einer aufgabe Java Basics - Anfänger-Themen 1
B BITTE!! Ich brauche dringende Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 17
Y Konkrete Hilfe gesucht - Anzahl der Stellen einer eingegebenen Zahl überprüfen Java Basics - Anfänger-Themen 5
U Brauche Hilfe bei Programmierung einer Produktdatenbank App Java Basics - Anfänger-Themen 4
E Erste Schritte brauche hilfe zum verstehen einer Klasse(Tiefensuche) Java Basics - Anfänger-Themen 17
A Vererbung Hilfe bei einer Aufgabenstellung Java Basics - Anfänger-Themen 3
G Hilfe bei einer NPE Java Basics - Anfänger-Themen 9
P Hilfe zu einer Aufgabe Java Basics - Anfänger-Themen 9
C Erste Schritte Benötige Hilfe mit einer Stoppuhr Java Basics - Anfänger-Themen 20
S Klassen Brauche Hilfe bei Erstellung einer Klasse für einen Tachenrechner!!! Java Basics - Anfänger-Themen 6
Q Vererbung Kleine Hilfe bei einer aufgabe Java Basics - Anfänger-Themen 5
B OOP Objekte erzeugen mit Hilfe einer for Schleife Java Basics - Anfänger-Themen 29
J HILFE Benutzen einer Klasse aus JRE System Library Java Basics - Anfänger-Themen 4
E Hilfe bei einer Methode Java Basics - Anfänger-Themen 4
H Hilfe bei einer add.methode Java Basics - Anfänger-Themen 6
C Methoden Objekte mit Hilfe einer Schleife in einer ArrayList erzeugen Java Basics - Anfänger-Themen 26
S Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 19
2 kapitalwertberechnung mit hilfe einer methode Java Basics - Anfänger-Themen 8
3 Bitte um Hilfe bei Lösung einer Aufgabe Java Basics - Anfänger-Themen 16
A Brauche Hilfe mit einer Forschleife Java Basics - Anfänger-Themen 20
S BITTE UM HILFE: Unterschied Deklaration und Signatur einer Methode Java Basics - Anfänger-Themen 3
N Bitte um Hilfe - zyklisch Existenz einer Datei prüfen Java Basics - Anfänger-Themen 21
K Hilfe bei einer Shrink Funktion Java Basics - Anfänger-Themen 8
P Zeilnumbruch vermeiden bei einer Tabelle *hilfe* Java Basics - Anfänger-Themen 11
F Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 2
N Hilfe zur Erstellung einer Internet-Plattform Java Basics - Anfänger-Themen 5
H Hilfe bei Ausgabe in einer Datei. Java Basics - Anfänger-Themen 5
R Hilfe! Daten aus einer excelliste auslesen und. Java Basics - Anfänger-Themen 3
K Bräuchte dringend Hilfe bei einer Schulaufgabe Java Basics - Anfänger-Themen 2
G Hilfe zur einer Aufgabe: Datumsüberprüfung beim Gregorianis Java Basics - Anfänger-Themen 2
G [Hilfe] Keys aus einer Map auslesen? Wie? Java Basics - Anfänger-Themen 3
Kerstininer Vererbung Hilfe beim lernen von Objektorientierung für eine Klausur Java Basics - Anfänger-Themen 10
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
E Hilfe bei rekursiver Funktion Java Basics - Anfänger-Themen 3
H pdf stempel - Hilfe erbeten Java Basics - Anfänger-Themen 6
KogoroMori21 Wann ist der richtige Zeitpunkt, um sich Hilfe zu suchen? (Bin Informatik-Student) Java Basics - Anfänger-Themen 10
A Hilfe beim Lesen von Pfaden und Systemvariablen Java Basics - Anfänger-Themen 3
F RegEx Hilfe Java Basics - Anfänger-Themen 5
S Hilfe bei Endlosschleife Java Basics - Anfänger-Themen 2
S Hilfe bei Praktischen Aufgaben von Arrays Java Basics - Anfänger-Themen 39
U Ich bräuchte Hilfe Java Basics - Anfänger-Themen 1
Say abstract class und Objekt erzeugen - Dringend Hilfe Java Basics - Anfänger-Themen 10
Justin4687 Benötige Hilfe bei folgender Aufgabe Java Basics - Anfänger-Themen 2
aero043 Hilfe bei BlueJ Hausübung Java Basics - Anfänger-Themen 27
P Hilfe gesucht Java Basics - Anfänger-Themen 11
D Hilfe bei Calculator Test Java Basics - Anfänger-Themen 15
R Hilfe bei Aufgabe Java Basics - Anfänger-Themen 4
Zentriks Hilfe zu Sieb des Eratosthenes ohne boolean Java Basics - Anfänger-Themen 5
R Java Bücher hilfe Java Basics - Anfänger-Themen 9
U HILFE! - per ActionListener Felder enablen....... Java Basics - Anfänger-Themen 5
I Scheduling: "Quartz" verwenden, Hilfe bei Umstellung Java Basics - Anfänger-Themen 3
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
L Hilfe! Liste mit Items werden ausgegeben aber nicht in zufälliger Reihenfolge Java Basics - Anfänger-Themen 6
Ekooekoo Hilfe spiel Java Basics - Anfänger-Themen 5
SpiritsHuner Hilfe!! Java Basics - Anfänger-Themen 16
Lacotto Java Kurs Aufgaben Hilfe Java Basics - Anfänger-Themen 14
M HILFE JPanel - Graphics Java Basics - Anfänger-Themen 1
X Hilfe beim Übertragen in eine For-Schleife Java Basics - Anfänger-Themen 1
Neuling47 Denkfehler? Hilfe Java Basics - Anfänger-Themen 11
S Hilfe bei Umänderung von Java Code Java Basics - Anfänger-Themen 16
X Erste Schritte Hilfe bei einem kleinen Spiel. Java Basics - Anfänger-Themen 19
D Bitte um Hilfe muss es schnellstmöglich erledigen Java Basics - Anfänger-Themen 15
L Hilfe bei RegEx Java Basics - Anfänger-Themen 4
I Bitte um Hilfe zu unterstehenden Code Java Basics - Anfänger-Themen 6
B Brauche Hilfe zu einem Code Java Basics - Anfänger-Themen 5
Neuling47 bräuchte dringend hilfe Java Basics - Anfänger-Themen 6
D Bräuchte Hilfe im Bezug zum printarray() Java Basics - Anfänger-Themen 4
M Bitte um Hilfe bei 2DArrays Java Basics - Anfänger-Themen 8
HeiTim Array hilfe Java Basics - Anfänger-Themen 14
M LCD-Ziffern-Hilfe Java Basics - Anfänger-Themen 6
özkan hilfe!! Java Basics - Anfänger-Themen 4
C Hilfe bei einem Anfängerprojekt Java Basics - Anfänger-Themen 25
D Abrechnung bitte um hilfe Java Basics - Anfänger-Themen 25
J Brauche Hilfe bei for-each Aufgabe Java Basics - Anfänger-Themen 1
D Zahlentabelle Anfänger braucht Hilfe Java Basics - Anfänger-Themen 1
HeiTim Brauche Hilfe soll ein nummeriertes Feld ausgeben lassen Java Basics - Anfänger-Themen 17
S Interaktive Abfrage, Hilfe mit Schleifen! Java Basics - Anfänger-Themen 6
N Hilfe bei der Installation Java Basics - Anfänger-Themen 2
J Brauche Hilfe bei Aufgabe Java Basics - Anfänger-Themen 4
enjoykimii Strukturierte Programmierung Hilfe Java Basics - Anfänger-Themen 29
H Bräuchte hilfe Java Basics - Anfänger-Themen 3
D Snake-Spiel ähnliche Aufgabe Hilfe Java Basics - Anfänger-Themen 3
H Brauche Hilfe Java Basics - Anfänger-Themen 2
D Dijkstra Algorithmus Hilfe!! Java Basics - Anfänger-Themen 9
H Hilfe Java Basics - Anfänger-Themen 6
H Brauche hilfe Java Basics - Anfänger-Themen 3
M Hilfe - Array Aufgabe Java Basics - Anfänger-Themen 8
R Schulaufgabe, Bruache Hilfe mit non-static Methoden Java Basics - Anfänger-Themen 2
kevkev Hilfe bei Schiffe versenken Java Basics - Anfänger-Themen 5
FelixxF Erste Schritte Hilfe bei Fußball Manager Java Basics - Anfänger-Themen 2
C Brauche Hilfe beim Schreiben eines Programmes :/ Java Basics - Anfänger-Themen 1

Ähnliche Java Themen

Neue Themen


Oben