Dies ist eine alte Version des Dokuments!
Levelorder Traversierung, Iterative Tiefensuche
Bei den drei rekursiv implementierbaren Traversierungen wird der Baum zuerst in die Tiefe durchwandert bis hin zu seinen Blättern ("Tiefensuche") - hier noch einmal am Beispiel bei der Preorder-Traversierung:
Bei der Levelorder Traversierung werden auf jedem Niveau des Baums erst alle Knoten besucht, bevor auf das nächste Niveau gewechselt wird, in unserem Beispielbaum ergibt sich damit die Traversierungsreihenfolge: A→B→F→C→D→G→E
. Der Algorithmus zur Levelorder Traversierung ist nicht rekursiv.
Iterative Traversierung
Die rekursiven Implementationen der Traversierungen versagen ihren Dienst, wenn die Bäume zu tief werden, da der Call-Stack für die Rekursion nicht beliebig wachsen kann. Bei Java ist seine Größe auf ca. 256kB beschränkt, wenn diese Größe überschritten wird, erhältst du einen Stack Overflow Error:
Die einfachste Lösung für dieses Problem ist es, den Stack, in dem man darüber Buch führt, welche Knoten des Baums als nächstes zu bearbeiten sind, selbst zu verwalten.
Filename | Filesize | Last modified |
---|---|---|
baeume_traversierung_iterativ.odp | 106.8 KiB | 14.02.2022 14:21 |
baeume_traversierung_iterativ.pdf | 170.4 KiB | 14.02.2022 14:21 |
levelorder.gif | 44.1 KiB | 14.02.2022 19:37 |
stackoverflow.png | 13.9 KiB | 14.02.2022 14:24 |