Arraylist als Pfadausgabe

Fohnbit

Top Contributor
Hallo,

ich habe die Klasse: Category:
Java:
public class Category {
private Integer id;
    private Integer parent_id;
    private String name;
    private Boolean is_active;
    private Integer position;
    private Integer level;
    private String children;
    private String created_at;
    private String updated_at;
    private String path;
    private List<String> available_sort_by;
    private Boolean include_in_menu;
    private ExtensionAttributes extension_attributes;
    private List<CustomAttribute> custom_attributes;
   private List<Category> children_data;

Diese widerum hat eine List der children_data als Category.

Sie ist also Rekursiv.

Nun benötige ich die ID von:
Default/Cat1/Cat5/demo

Die genannten sind die namen der Kategorien.

Habs nun nicht getestet, aber Rekursiv müsste ich die Category "demo" so finden:
Java:
public int getCategoryByName(Category category, String name) {
        if (category.getName().equals(name)) {
            return category.getId();
        }

        for (Category childs : category.getChildren_data()) {
            return getCategoryByName(childs, name);
        }
        return 0;
    }

Aber es könnte sein das eine andere Kategorie in einem anderen Pfad auch "demo" heißt.

Wie könnte ich die Rekursive Liste mit einer Suche nach "Default/Cat1/Cat5/demo" genau finden?

Danke!
 

mrBrown

Super-Moderator
Mitarbeiter
Das "Default/Cat1/Cat5/demo" kannst du am '/' splitten, dann bekommst du eine Liste von Namen.

Dann, nicht rekursiv sondern nur auf einer Ebene, nach "Default" suchen.
Wenn du das gefunden hast, in deren direkten Kindern nach "Cat1" suchen.
Und dass dann solange mit dem jeweils nächsten Pfadelement, bis du am Ende angekommen bist.

Müsste als rekursive Funktion recht leicht umzusetzen sein
 

Fohnbit

Top Contributor
Hallo,

ja, mit dem Splitten hab ich es mal versucht .. nun, es scheint alle korrekt zurück zu geben, aber geht das auch einfacher? :)

Die erste Category "Root Catalog" muss ich überspringen:
Suche nach "Default Category/Werkzeug und Maschinen/Werkzeug" gibt das passende Ergebniss zurück.

Java:
public Category getCategoryByName(Category category, String[] name, int level) {
        if (!category.getName().equals("Root Catalog")) {
            if (category.getName().equals(name[level])) {
                if (name.length == level + 1) {
                    // gefunden!
                    return category;
                }
                for (Category childs : category.getChildren_data()) {
                    level++;
                    Category cat = getCategoryByName(childs, name, level);
                    if (cat != null) {
                        return cat;
                    } else {
                        level--;
                    }
                }
            }
            return null;

        } else {
            for (Category childs : category.getChildren_data()) {
                Category cat = getCategoryByName(childs, name, level);
                if (cat != null) {
                    return cat;
                } else {
                    return null;
                }
            }
        }
        return category;
    }
 

mihe7

Top Contributor
Mal so als Idee:
Java:
public Category getCategoryByPath(String[] path) {
    Category current = this;
    // mit i = 1 wird erstes Element ausgelassen
    for (int i = 1; current != null && i < path.length; i++) {
        current = getChildByName(path[i]);
    }
    return current;
}

public Category getChildByName(String name) {
    for (Category child : children_data) {
        if (child.name.equals(name)) {
            return child;
        }
    }
    return null;
}
 

Fohnbit

Top Contributor
Danke!

@mrBrown Genau, ist die Wurzel und nur die Childs werden durchsucht

@mihe7 hmmm ... ist dein Code auf 2 Ebenen beschränkt? Müsste nicht bei "getChildByName" wiederum die Suche starten?
 

mihe7

Top Contributor
ist dein Code auf 2 Ebenen beschränkt? Müsste nicht bei "getChildByName" wiederum die Suche starten?
Nein. Bei getChildByName geht es nur darum, die direkte(!) Subkategorie der aktuellen Kategorie anhand des Namens zu finden. getCategoryByPath funktioniert dann einfach folgendermaßen:
1. es wird mit der Kategorie, auf der getCategoryByPath aufgerufen wurde gestartet. Die aktuelle Kategorie ist damit this.
2. Für jedes Pfadelement wird der Reihe nach:
- von der jeweils aktuellen Kategorie die direkte Subkategorie anhand des Pfadelements gesucht
- die so gefundene (oder auch nicht gefundene) Subkategorie wird zur neuen aktuelle Kategorie gemacht

Das ganze geht so lange, bis eine Subkategorie nicht gefunden wurde oder alle Pfadelemente durch sind.
 

Fohnbit

Top Contributor
@mihe7 vielen Dank.
Ich musst eine Kleinigkeit abändern:
Java:
    public Category getCategoryByPath(String[] path) {
        Category current = this;
        // mit i = 1 wird erstes Element ausgelassen
        for (int i = 0; current != null && i < path.length; i++) {
            current = getChildByName(current, path[i]);
        }
        return current;
    }

    public Category getChildByName(Category current, String name) {
        for (Category child : current.getChildren_data()) {
            if (child.name.equals(name)) {
                return child;
            }
        }
        return null;
    }

Da du nur auf die Childs prüfst, wird der "Root name" sowieso übersprungen. Denk du dachtest vom "path" sollte der erst übersprungen werden.

"children_data" würde sich sonst ja auf die interne lokale Variable "children_data" beziehen und nicht auf die der "current".
So wie oben klappt das nun.
 

mihe7

Top Contributor
Oops, ja beim Aufruf das current vergessen: current = current.getChildByName(path[i]); so gehts objekt-orientiert auch ohne Parameter.
 
X

Xyz1

Gast
Sie ist also Rekursiv
Rekursion ist, insofern wir nicht von Methoden sprechen, nicht der richtige Begriff. Sag einfach gerichteter azyklischer Graph dann weiß jeder Bescheid :rolleyes: leider werden von vielen Anfängern falsche Begriffe verwendet und andere übernehmen dann einfach - ohne kritisch zu hinterfragen....

Zweitens. Rein rekursiv ist das nicht möglich, da eine Category, nimmt man es genau, bei einer Rekursion nur sich selber kennt aber alle in der gleichen Ebene kennen müsste. Also ist diese Aufgabenstellung wirklich Nonsense...
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
krgewb ArrayList allgemein halten Java Basics - Anfänger-Themen 6
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J ArrayList vergleichen im spiel Mastermind Java Basics - Anfänger-Themen 2
Mugetsu35 ArrayList Update ohne Index Java Basics - Anfänger-Themen 6
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
Z Java ArrayList speichert falsche Daten ab bzw. gibt falsche Daten aus? Java Basics - Anfänger-Themen 42
W if-Abfrage bei ArrayList-Methodenaufrufen - Wie löse ich das? Java Basics - Anfänger-Themen 6
W ArrayList und toString Java Basics - Anfänger-Themen 17
volcanos Addition -> List<Integer> mit Arrays.asList() versus List<Integer>ArrayList<>() Java Basics - Anfänger-Themen 14
ArrayList mit unbekannter Menge an Arrays die Arrays vergleichen Java Basics - Anfänger-Themen 9
M 2d ArrayList durchgehen Java Basics - Anfänger-Themen 2
Blkckroll45 Arraylist Java Basics - Anfänger-Themen 6
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
berserkerdq2 Geht collections.sort bei allen? Linkedhashset, ArrayList, HashSet etc. Java Basics - Anfänger-Themen 4
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
D Arraylist mit Komplexen Datentyp Java Basics - Anfänger-Themen 3
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
volcanos List & ArrayList nach Familiennamen abfragen Java Basics - Anfänger-Themen 57
M static ArrayList in non-static Java Basics - Anfänger-Themen 12
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
M ArrayList<TreeNode<T>> fortlaufende Nummerierung der Elemente Java Basics - Anfänger-Themen 5
B Bungeecord | ProxiedPlayer wird nicht in ArrayList hinzugefügt Java Basics - Anfänger-Themen 1
S ArrayList Username und passwort mit JTextField eingaben abgleichen Java Basics - Anfänger-Themen 10
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
F Erste Schritte Zahlenreihe von Arraylist in 3erBlöcke sortiert in neue Arraylist Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
F Methode ArrayList mit Eingabewert Java Basics - Anfänger-Themen 2
J ArrayList add methode selbst programmieren Java Basics - Anfänger-Themen 10
K Erste Schritte Wie schnell ist LinkedHashMap im Vergleich zur ArrayList, wenn alle Entries durchlaufen werden? Java Basics - Anfänger-Themen 47
thobren jtable arraylist Java Basics - Anfänger-Themen 12
N Exception beim Verwenden von Arraylist? Java Basics - Anfänger-Themen 10
P Schiebefix - ArrayList überschreibt Daten Java Basics - Anfänger-Themen 3
Zeppi OOP ArrayList Java Basics - Anfänger-Themen 2
P ArrayList Java Basics - Anfänger-Themen 4
L ArrayList auf 4 Elemente begrenzen Java Basics - Anfänger-Themen 56
C ArrayList sortieren nach bestimmten Buchstaben in den Wörtern Java Basics - Anfänger-Themen 13
S Arraylist<Object> mit verschiedenen Objects ausgeben Java Basics - Anfänger-Themen 3
J ArrayList auf bereits vorhanden eintrag prüfen Java Basics - Anfänger-Themen 5
M For Schleife/ArrayList Java Basics - Anfänger-Themen 12
L ArrayList<String> --> double[] array Java Basics - Anfänger-Themen 18
L Längstes Element einer ArrayList ausgeben Java Basics - Anfänger-Themen 9
S Aus verschachtelter ArrayList auf einen Wert zugreifen Java Basics - Anfänger-Themen 4
L Methoden ArrayList Werte hinzufügen und löschen Java Basics - Anfänger-Themen 32
M ArrayList in GUI ausgeben Java Basics - Anfänger-Themen 1
J Nur bestimmter Typ aus der ArrayList ausgeben. Java Basics - Anfänger-Themen 9
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
Bademeister007 Operatoren Alle Zahlen einer ArrayList die durch 5 teilbar ist Java Basics - Anfänger-Themen 2
S Objekt aus Arraylist in andere Arraylist kopieren? Java Basics - Anfänger-Themen 2
C Sortieren einer ArrayList Java Basics - Anfänger-Themen 2
krgewb ArrayList von ArrayList Java Basics - Anfänger-Themen 2
R ArrayList Problem Java Basics - Anfänger-Themen 6
jonny_2k12 Wie kann ich eine ArrayList aus einer Klasse in eine andere übergeben? Java Basics - Anfänger-Themen 21
O Namen (mit Umlauten und ß) in einer ArrayList suchen Java Basics - Anfänger-Themen 5
N Typebound Objekte einer Arraylist hinzufügen Java Basics - Anfänger-Themen 7
R Methoden ArrayList clonen wirft exception Java Basics - Anfänger-Themen 3
S ArrayList in andere Klasse übernhemen Java Basics - Anfänger-Themen 5
M Letztes Element einer ArrayList Java Basics - Anfänger-Themen 12
B Objektverwaltung mit ArrayList in einer seperaten Klasse Java Basics - Anfänger-Themen 24
I Sortiert eine HashMap nicht gleich wie eine ArrayList? Java Basics - Anfänger-Themen 1
I ArrayList erstellen innerhalb einer Zeile? Java Basics - Anfänger-Themen 3
L Iterieren durch eine ArrayList. Integer Array wird übergeben Java Basics - Anfänger-Themen 17
V Collections ArrayList mit Comparator sortieren Java Basics - Anfänger-Themen 16
D Collections Arrays in ArrayList abspeichern Java Basics - Anfänger-Themen 6
F java.util.ArrayList Java Basics - Anfänger-Themen 3
M ArrayList - Objekt kopieren und ändern Java Basics - Anfänger-Themen 11
M Zugriff auf eine ArrayList in einer anderen Klasse Java Basics - Anfänger-Themen 4
P Arraylist zu einem Array bringen mit Verschachtelung Java Basics - Anfänger-Themen 11
N Methode mit einer Arraylist Java Basics - Anfänger-Themen 106
I ArrayList - Methode zum Speichern eines Eintrags in einer Datei Java Basics - Anfänger-Themen 17
H ArrayList Java Basics - Anfänger-Themen 7
D public ArrayList(Collection<? extends E> c); Java Basics - Anfänger-Themen 2
M JTextField in ArrayList speichern Java Basics - Anfänger-Themen 4
C ArrayList mit return zurückgeben Java Basics - Anfänger-Themen 13
K Zahlenfolge ArrayList Java Basics - Anfänger-Themen 3
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
I Klassen Eine ArrayList<Long>, die sich automatisch sortiert Java Basics - Anfänger-Themen 20
F Array in ArrayList ablegen Java Basics - Anfänger-Themen 3
V ArrayList Java Basics - Anfänger-Themen 1
Z Runden Arraylist Java Basics - Anfänger-Themen 9
X Frage zur einer ArrayList in einer ArrayList Java Basics - Anfänger-Themen 5
L Daten aus ArrayList in Datenbank durchsuchen Java Basics - Anfänger-Themen 5
L Objekt aus Textdatei in ArrayList speichern Java Basics - Anfänger-Themen 4
M Problem mit ArrayList Java Basics - Anfänger-Themen 32
X Objekte einer ArrayList richtig ausgeben? Java Basics - Anfänger-Themen 8
O Hashmap, ArrayList, LinkedList Java Basics - Anfänger-Themen 7
X Problem mit Arraylist in Arraylist Java Basics - Anfänger-Themen 2
O HashMap - ArrayList Java Basics - Anfänger-Themen 29
M UML-Klassendiagramm ArrayList Java Basics - Anfänger-Themen 1
O ArrayList oberflächig durchsuchen Java Basics - Anfänger-Themen 3
I "\n" aus ArrayList enfernen, aber wie?! Java Basics - Anfänger-Themen 4
V Collections Objekte einer ArrayList in der main() ausgeben Java Basics - Anfänger-Themen 9
Jackii ArrayList ausgabe ohne Dopplung Java Basics - Anfänger-Themen 11
N ArrayList in eigener Klasse erzeugen mit Zugriff Java Basics - Anfänger-Themen 7

Ähnliche Java Themen

Neue Themen


Oben