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
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.
publicCategorygetCategoryByPath(String[] path){Category current =this;// mit i = 1 wird erstes Element ausgelassenfor(int i =1; current !=null&& i < path.length; i++){
current =getChildByName(path[i]);}return current;}publicCategorygetChildByName(String name){for(Category child : children_data){if(child.name.equals(name)){return child;}}returnnull;}
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.
@mihe7 vielen Dank.
Ich musst eine Kleinigkeit abändern:
Java:
publicCategorygetCategoryByPath(String[] path){Category current =this;// mit i = 1 wird erstes Element ausgelassenfor(int i =0; current !=null&& i < path.length; i++){
current =getChildByName(current, path[i]);}return current;}publicCategorygetChildByName(Category current,String name){for(Category child : current.getChildren_data()){if(child.name.equals(name)){return child;}}returnnull;}
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.
Rekursion ist, insofern wir nicht von Methoden sprechen, nicht der richtige Begriff. Sag einfach gerichteter azyklischer Graph dann weiß jeder Bescheid 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...