Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Algorithmen, Datenstrukturen und Klassendesign (https://www.delphipraxis.net/78-algorithmen-datenstrukturen-und-klassendesign/)
-   -   Rekursive Procedure funktioniert nicht auf oberster Ebene im Baum? (https://www.delphipraxis.net/154424-rekursive-procedure-funktioniert-nicht-auf-oberster-ebene-im-baum.html)

Grolle 10. Sep 2010 08:58

Rekursive Procedure funktioniert nicht auf oberster Ebene im Baum?
 
Hallo,

ich habe eine rekursive Procedure, welche nicht in der obersten Ebene im Baum funktioniert. Ziel ist es alle Unterknoten eines Knotens auszulesen:
Delphi-Quellcode:
procedure Tlft.getSubnoteIds(var inList : TStringList; const inNode : TTreeNode);
begin
  if assigned(inNode) then
  begin
    inList.Add(inNode.Text);
    getSubnoteIds(inList,inNode.getFirstChild);
    getSubnoteIds(inList,inNode.getNextSibling);
  end;
end;
Wähle ich einen Knoten auf der obersten Ebene werden alle weiteren Knoten in der obersten Ebene abgegrast :?

Viele Grüße ...

jfheins 10. Sep 2010 09:03

AW: Rekursive Procedure funktioniert nicht auf oberster Ebene im Baum?
 
Vielleicht solltest du statt den Silbings (also Knoten gleichen Levels) lieber alle Kinder durchgehen ;)

=> Delphi-Referenz durchsuchenTTreeNode.GetNextChild

himitsu 10. Sep 2010 09:03

AW: Rekursive Procedure funktioniert nicht auf oberster Ebene im Baum?
 
Dann laß doch
Delphi-Quellcode:
getSubnoteIds(inList,inNode.getNextSibling);
einfach weg?

PS: Mit dieser Zeile sollte es überigens auf allen Ebenen nicht so funktionieren, wie du willst.

JasonDX 10. Sep 2010 09:04

AW: Rekursive Procedure funktioniert nicht auf oberster Ebene im Baum?
 
Zitat:

Zitat von Grolle (Beitrag 1048604)
Delphi-Quellcode:
procedure Tlft.getSubnoteIds(var inList : TStringList; const inNode : TTreeNode);
begin
  if assigned(inNode) then
  begin
    //...
    getSubnoteIds(inList,inNode.getNextSibling);
  end;
end;
Wähle ich einen Knoten auf der obersten Ebene werden alle weiteren Knoten in der obersten Ebene abgegrast :?

Das Codestück sollte zeigen wieso. Einfachere Variante: Du fügst den aktuellen Knoten zur Liste hinzu, und iterierst dann über die Kinder und rufst die Funktion rekursiv auf. Ansonsten brauchst du für den obersten Knoten ein anderes Verhalten als für die Kindknoten, eben genau den Nachbarn nicht mitzunehmen. Ist zwar nicht so kurz, funktioniert dafür aber mit dem selben Code für alle Knoten ;)

@himitsu: Das getNextSibling brauchts, um dann alle Kindknoten herzukriegen. Der Rekursionsbaum ist sozusagen die Binärbaum-Darstellung der TreeView.

greetz
Mike

Grolle 10. Sep 2010 09:16

AW: Rekursive Procedure funktioniert nicht auf oberster Ebene im Baum?
 
Hallo,

die Procedure ist schon richtig, der Trick war wirklich die Übergabe des ersten Childknoten und den gewählten extra Knoten zu behandeln.

Danke 8-)


Alle Zeitangaben in WEZ +1. Es ist jetzt 18:58 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz