Διδάσκων: Παναγιώτης Ανδρέου

Σχετικά έγγραφα
Διάλεξη 11: Δέντρα Ι Εισαγωγή σε Δενδρικές Δομές Δεδομένων

Διάλεξη 11: Δέντρα Ι - Εισαγωγή σε Δενδρικές Δομές Δεδομένων

Δένδρα. Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα:

Διδάσκων: Κωνσταντίνος Κώστα

Διάλεξη 22: Δυαδικά Δέντρα. Διδάσκων: Παναγιώτης Ανδρέου

Διδάσκων: Παναγιώτης Ανδρέου

Διάλεξη 12: Δέντρα ΙΙ Δυαδικά Δέντρα

Γηάιεμε 16: Δηζαγσγή ζε Γελδξηθέο Γνκέο Γεδνκέλσλ

Διάλεξη 17: Δυαδικά Δέντρα. Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ

Διάλεξη 11: Φροντιστήριο για Στοίβες. Διδάσκων: Παναγιώτης Ανδρέου. ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ.

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ

ένδρα (tail, head) Γονέας Παιδί (ancestor, descendant) Φύλλο Εσωτερικός Κόµβος (leaf, non-leaf) που αποτελεί το γονέα του v.

Διάλεξη 26: Σωροί. Διδάσκων: Παναγιώτης Ανδρέου

Διάλεξη 29: Γράφοι. Διδάσκων: Παναγιώτης Ανδρέου

Δομές Δεδομένων και Αλγόριθμοι

ένδρα u o Κόµβοι (nodes) o Ακµές (edges) o Ουρά και κεφαλή ακµής (tail, head) o Γονέας Παιδί Αδελφικός κόµβος (parent, child, sibling) o Μονοπάτι (pat

Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων ομές εδομένων

Διάλεξη 12: Λίστες Υλοποίηση & Εφαρμογές. Διδάσκων: Παναγιώτης Ανδρέου

Δηµοσθένης Σταµάτης Τµήµα Πληροφορικής ΑΤΕΙ ΘΕΣΣΑΛΟΝΙΚΗΣ ΔΕΝΤΡΑ (TREES) B C D E F G H I J K L M

ΑΛΓΟΡΙΘΜΟΙ ΜΕ C. ΝΙΚΟΛΑΟΣ ΣΑΜΑΡΑΣ Αναπληρωτής Καθηγητής. CMOR Lab. Computational Methodologies and Operations Research

Διδάσκων: Παναγιώτης Ανδρέου

Δομές Δεδομένων & Αλγόριθμοι

ΕΝΟΤΗΤΑ 4 ΕΝ ΡΑ. ΗΥ240 - Παναγιώτα Φατούρου 1

Διάλεξη 18: B-Δένδρα

Μάθημα 22: Δυαδικά δέντρα (Binary Trees)

Δομές Δεδομένων. Καθηγήτρια Μαρία Σατρατζέμη. Τμήμα Εφαρμοσμένης Πληροφορικής. Δομές Δεδομένων. Τμήμα Εφαρμοσμένης Πληροφορικής

Δομές Δεδομένων (Data Structures)

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ

οµές εδοµένων 3 ο Εξάµηνο ΕΝΟΤΗΤΑ 4 ΕΝ ΡΑ

Διάλεξη 9: Αφηρημένοι Τύποι Δεδομένων. Διδάσκων: Παναγιώτης Ανδρέου

Διδάσκων: Παναγιώτης Ανδρέου

Κατ οίκον Εργασία 3 Σκελετοί Λύσεων

Βασικές Δομές Δεδομένων

Εργαστήριο 4: Υλοποίηση Αφηρημένου Τύπου Δεδομένων: Ταξινομημένη Λίστα

Επιλογές και Κριτήρια Σχεδιασμού ΑΤΔ Ανεξαρτήτως από Γλώσσα Υλοποίησης 24/4/2012

Αλγόριθμοι και Δομές Δεδομένων (IΙ) (γράφοι και δένδρα)

ΗΥ240 - Παναγιώτα Φατούρου 1

Μελετάμε την περίπτωση όπου αποθηκεύουμε ένα (δυναμικό) σύνολο στοιχειών. Ένα στοιχείο γράφεται ως, όπου κάθε.

Δένδρα. Μαθηματικά (συνδυαστικά) αντικείμενα. Έχουν κεντρικό ρόλο στην επιστήμη των υπολογιστών :

Δομές Δεδομένων Ενότητα 5

Δυαδικά Δένδρα Αναζήτησης, Δένδρα AVL

ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 5. Αφηρημένοι Τύποι Δεδομένων / Στοίβες και Ουρές

ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ. Δομές δεδομένων. Ενότητα 3η: Δένδρα Παναγιώτα Φατούρου Τμήμα Επιστήμης Υπολογιστών

Διάλεξη 14: Δέντρα IV B Δένδρα. Διδάσκων: Παναγιώτης Ανδρέου

Δομές Δεδομένων. Ενότητα 10: Πλήρη Δυαδικά Δέντρα, Μέγιστα/Ελάχιστα Δέντρα & Εισαγωγή στο Σωρό- Ο ΑΤΔ Μέγιστος Σωρός. Καθηγήτρια Μαρία Σατρατζέμη

ΠΛΗ111. Ανοιξη Μάθηµα 7 ο. έντρο. Τµήµα Ηλεκτρονικών Μηχανικών και Μηχανικών Υπολογιστών Πολυτεχνείο Κρήτης

Διάλεξη 24: B-Δένδρα. Διδάσκων: Παναγιώτης Ανδρέου

Κατ οίκον Εργασία 3 Σκελετοί Λύσεων

Εργαστήριο 5 Αναδρομική διεργασία εισαγωγής καινούριου κόμβου σε ΔΔΑ με αλφαβητική σειρά

Διάλεξη 16: Σωροί. Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Ουρές Προτεραιότητας - Ο ΑΤΔ Σωρός, Υλοποίηση και πράξεις

ΠΑΡΑΡΤΗΜΑ: QUIZ ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ

ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ EPL035: ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ ΚΑΙ ΑΛΓΟΡΙΘΜΟΙ

Εργαστήριο 8: Αναδρομική διεργασία εισαγωγής καινούριου κόμβου σε ΔΔΑ

Δομές Αναζήτησης. κλειδί από ολικά διατεταγμένο σύνολο. Θέλουμε να υποστηρίξουμε δύο βασικές λειτουργίες: Εισαγωγή ενός νέου στοιχείου

Κεφάλαιο 10 Ψηφιακά Λεξικά

Διδάσκων: Κωνσταντίνος Κώστα

Διάλεξη 13: Δέντρα ΙΙΙ Ισοζυγισμένα Δέντρα, AVL Δέντρα. Διδάσκων: Παναγιώτης Ανδρέου

υαδικό έντρο Αναζήτησης (BSTree)

Ενότητες 3 & 4: Δένδρα, Σύνολα & Λεξικά Ασκήσεις και Λύσεις

ΕΠΛ 231 οµές εδοµένων και Αλγόριθµοι Άννα Φιλίππου,

Διάλεξη 05: Αφηρημένοι Τύποι Δεδομένων

Οντοκεντρικός Προγραμματισμός

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ

Διάλεξη 1: Δομές Δεδομένων και Αλγόριθμοι - Εισαγωγή. Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ

Διδάσκων: Παναγιώτης Ανδρέου

Υλοποίηση Λιστών. Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα:

Βασικές Δοµές Δεδοµένων. Σύντοµη επανάληψη (ΕΠΛ 035).

8.6 Κλάσεις και αντικείμενα 8.7 Δείκτες σε γλώσσα μηχανής

Στοίβες με Δυναμική Δέσμευση Μνήμης

Δομές Δεδομένων. Δημήτρης Μιχαήλ. Δέντρα Αναζήτησης. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο

Διάλεξη 14: Δέντρα IV - B-Δένδρα

Διάλεξη 16: Σωροί. Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Ουρές Προτεραιότητας - Ο ΑΤΔ Σωρός, Υλοποίηση και πράξεις

ΕΠΛ 231 Δοµές Δεδοµένων και Αλγόριθµοι 11-1

AVL-trees C++ implementation

Βασικές οµές εδοµένων

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ

Γράφημα. Συνδυαστικό αντικείμενο που αποτελείται από 2 σύνολα: Σύνολο κορυφών (vertex set) Σύνολο ακμών (edge set) 4 5 πλήθος κορυφών πλήθος ακμών

Διδάσκων: Παναγιώτης Ανδρέου ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι

ΣΧΟΛΗ ΔΙΟΙΚΗΣΗΣ ΚΑΙ ΟΙΚΟΝΟΜΙΑΣ ΤΜΗΜΑ ΔΙΟΙΚΗΣΗΣ ΕΠΙΧΕΙΡΗΣΕΩΝ (ΠΑΤΡΑ) ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Βασικές Ιδιότητες και Διάσχιση Κεφάλαιο 5 ( και ) Ε. Μαρκάκης Επίκουρος Καθηγητής

Δομές Δεδομένων. Δημήτρης Μιχαήλ. Ουρές Προτεραιότητας. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο

ΗΥ360 Αρχεία και Βάσεις εδοµένων

Πανεπιστήμιο Δυτικής Μακεδονίας. Τμήμα Μηχανικών Πληροφορικής & Τηλεπικοινωνιών. Διακριτά Μαθηματικά. Ενότητα 3: Δένδρα

Προγραμματισμός Ι (ΗΥ120)

Διάλεξη 13: Δέντρα ΙΙΙ Ισοζυγισμένα Δέντρα, AVL Δέντρα

Insert(K,I,S) Delete(K,S)

Διάλεξη 13: Δέντρα ΙΙΙ - Ισοζυγισμένα Δέντρα, AVL Δέντρα

ιαφάνειες παρουσίασης #10 (β)

Δομές Δεδομένων (Data Structures)

ΚΕΦΑΛΑΙΟ 8: Αφαίρεση δεδοµένων

#2 Αλγόριθµοι, οµές εδοµένων και Πολυπλοκότητα

ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ. ΑΣΚΗΣΗ 3 Δέντρα

ιαφάνειες παρουσίασης #11

Δομές Δεδομένων. Ενότητα 9: Τα ΔΔΑ ως Αναδρομικές Δομές Δεδομένων-Εφαρμογή Δυαδικών Δέντρων: Κωδικοί Huffman. Καθηγήτρια Μαρία Σατρατζέμη

5 ΔΕΝΤΡΑ (Trees) Σχήµα 5.1 : ενδροειδής αναπαράσταση αρχείων στα Windows. έντρα. \ {root directory} Accessories. Program Files.

Διάλεξη 21η: Απλά Συνδεδεμένες Λίστες

Φροντιστήριο 4 Σκελετοί Λύσεων

ΗΥ240: Δομές Δεδομένων Εαρινό Εξάμηνο Ακαδημαϊκό Έτος 2017 Διδάσκουσα: Παναγιώτα Φατούρου Προγραμματιστική Εργασία - 2o Μέρος

Γέφυρες σε Δίκτυα. Μας δίνεται ένα δίκτυο (κατευθυνόμενο γράφημα) αφετηριακός κόμβος. Γέφυρα του (με αφετηρία τον ) :

ΕΝΟΤΗΤΑ 7 ΟΥΡΕΣ ΠΡΟΤΕΡΑΙΟΤΗΤΑΣ ΣΩΡΟΙ

Transcript:

Διάλεξη 21: Εισαγωγή σε Δενδρικές Δομές Δεδομένων Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: -Εισαγωγή σε δενδρικές δομές δεδομένων, -Ορισμοί και πράξεις - Αναπαράσταση δενδρικών δομών δεδομένων στη μνήμη - Διάσχιση Δέντρων Διδάσκων: Παναγιώτης Ανδρέου ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 1

Δέντρα Μέχρι τώρα μελετούσαμε γραμμικέςδομές δεδομένων (linear data structures) π.χ. Stacks, queues, arrays, lists, κτλ Σε αυτή την ενότητα θα μελετήσουμε δενδρικές δομές δεδομένων (δηλαδή μη-γραμμικές δομές) Δένδροείναι ένα σύνολο κόμβων(κορυφών) που συνδέονται από ακμές (ή τόξα). ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 2

Δέντρα Δένδροείναι ένα σύνολο κόμβων(κορυφών) που συνδέονται από ακμές (ή τόξα) με τον ακόλουθο αναδρομικό ορισμό: 1. Ένα δένδρο είναι είτε κενό ή 2. αποτελείται από: μια ρίζα(root),δηλαδή ένα κόμβο στον οποίο δεν καταλήγουν αλλά μόνο ξεκινούν ακμές, και 0 ή περισσότερα υποδένδρατ 1, Τ 2,,, Τ k, το καθένα ξεχωριστό από τα άλλα και από τη ρίζα. Υπάρχει μια ακμή από τη ρίζα στις ρίζες των Τ 1, Τ 2,,, Τ k. Από κάθε κόμβο ξεκινούν 0 ή περισσότερες ακμές(edges). Σε κάθε κόμβο καταλήγει μία μόνο ακμή(αλλιώς θα είχαμε μια άλλη δομή τον γράφο) Στη ρίζα δεν καταλήγει καμιά ακμή. ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 3

Παράδειγμα 1: Οργάνωση Μονοπατιών σε ένα OS /usr root /maria /christos /yiannis Ακµές (edges) /courses /mail /.netscape /epl034 /epl035 /homeworks /notes hw1 Υποδεντρό (subtree) ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 4

Παράδειγμα συνέχεια Υποθέστε ότι χρησιμοποιούσαμε μια γραμμική δομή(π.χ. ένα πίνακα) για την αποθήκευση των διάφορων μονοπατιών /usr/maria /usr/christos /usr/christos/courses /usr/christos/courses/epl034 /usr/christos/courses/epl035 /usr/christos/courses/epl035/homeworks /usr/christos/courses/epl035/homeworks/hw1 /usr/christos/courses/epl035/notes /usr/christos/mail /usr/christos/.netscape /usr/yiannis Μειονεκτήματα Καταλαμβάνουμε πολύ χώρο Επαναληπτική αποθήκευση μονοπατιού Η αναζήτηση κάποιου στοιχείου χρειάζεται Ο(n) (n μέγεθος λίστας) Στα δένδρα τα δεδομένα είναι καλύτερα οργανωμένα ώστε οι διαδικασίες αναζήτησης, εισαγωγής και εξαγωγής κόμβου να είναι πιο αποδοτικές( O(logn)). ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 5

Παράδειγμα 2: Suffix Trie (ReTrieval) Μπορούμε να κρατήσουμε ένα μεγάλο λεξικό στην μνήμη του υπολογιστή και να κάνουμε αναζητήσεις για λέξεις αποδοτικά PATRICIA Trie: Κάθε ακμή περιέχει 1 ή περισσότερους χαρακτήρες (συμπίεση) ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 6

Ορισμοί Όταν υπάρχει ακμήαπό ένα κόμβο uσε ένα κόμβο v τότε οuείναι ο πατέραςή ο προκάτοχος (parent) του v, και ο v είναι παιδί(child) του u. Η ορολογία αυτή γενικεύεται ώστε να μιλούμε για προγόνους(ancestors) και απογόνους (descendants) κόμβων. Κόμβοι που έχουν τον ίδιο προκάτοχο ονομάζονται αδέλφια(siblings) Κόμβοι που δεν έχουν παιδιά λέγονται φύλλα (leaves). Οι υπόλοιποι λέγονται εσωτερικοί(nonleaves - branches). Βαθμός (degree) ενός κόμβουείναι ο αριθμός των παιδιών του. Βαθμός ενός δένδρουείναι ο μέγιστοςαπό τους βαθμούς των κόμβων του. Δένδρα βαθμού nλέγονται n-αδικά. Δένδρα που χρησιμοποιούνται συχνά είναι τα δυαδικά (binary), τετραδικά (quadtrees), οκταδικά(octtrees). Parent(6) => 3 Sibling(1) => 6 Leaves = {1,4,7,13} Non-leaves={3,6,7,10,14} Root={7} Degree(Tree)=2 degree(14) = 1 ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 7

Βάθος και ύψος ενός δένδρου Βάθος ενός κόμβου(node Depth)(ή επίπεδοlevel) =>αριθμός προγόνων + 1. π.χ. το βάθος της ρίζας ενός δένδρου είναι 1. Βάθος(6)= 3 Βάθος ενός δένδρουονομάζουμε τον μέγιστο από τα βάθη των κόμβων. Ύψος(6): 1 Μονοπάτιή διαδρομή(path)ενός δένδρου είναι μια ακολουθία κόμβων v 1, v 2,,, v k, όπου κάθε v i είναι πατέρας του v i+1. Τομήκοςτου μονοπατιού v 1, v 2,,, v k είναι k-1. Ύψος ενός κόμβου: το μήκος του μονοπατιού από το βαθύτερο κόμβο (στο ίδιο υπό-δένδρο) προς τον κόμβο. π.χ. το ύψος οποιουδήποτε φύλλου είναι 0. Ύψος ενός δένδρου: το ύψος της ρίζας του δένδρου. ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 8

Παράδειγμα βάθος 37 37 37 Βάθος(Depth/Level) κόμβου:1 ύψος Ύψος (Height) κόμβου: 0 Βαθμός Δένδρου = 0 Βάθος (Δένδρου): 2 Ύψος (Δένδρου): 1 Βάθος κόμβου 37: 1 Ύψος κόμβου 37: 1 Βάθος κόμβου 24: 2 Ύψος κόμβου 24: 0 Βαθμός Δένδρου = 2 24 42 24 42 6 Βάθος (Δένδρου): 3 Ύψος (Δένδρου): 2 Βάθος κόμβου 24: 2 Ύψος κόμβου 24: 1 Βάθος κόμβου 6: 3 Ύψος κόμβου 6: 0 Βαθμός Δένδρου = 2 ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 9

Αναπαράσταση Δένδρων στη Μνήμη Μπορούμε να χρησιμοποιήσουμε στατική ή δυναμική χορήγηση μνήμης, αν και το δεύτερο είναι πιο φυσιολογικός τρόπος. Κάθε κόμβος αποτελείται από κάποιο αριθμό πεδίων: 1. Τα πραγματικά δεδομένα του κόμβου(data και το κλειδί), και 2. Δείκτες σε άλλους κόμβουςτου δένδρου (ένα ανά παιδί). typedef struct node { int data; struct node *left; struct node *right; } NODE; typedef struct stack { NODE *head; int size; } TREE; ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 10

Αναπαράσταση Δένδρων στη Μνήμη Για δένδρο βαθμού nκάθε κόμβος έχει την πιο κάτω μορφή: Info p 1 p 2 p n όπου ο p i είναι δείκτης στο i-οστό παιδί του κόμβου. Εναλλακτικά θα μπορούσαμε να αναπαραστήσουμε ένα δένδρο μέσα σε ένα στατικά ορισμένο πίνακα. Π.χ. όπου οι δείκτες είναι απλά αριθμοί (θέσεις του πίνακα). Και στις δυο περιπτώσεις θέλουμε 4 bytesανά δείκτη (σε x86) ή integer θέσης πίνακα.αν έχουμε ένα 5-αδικό δέντρο τότε κάθε κόμβος χρειάζεται επιπλέον 20 bytes. Αν ένας κόμβος δεν έχει παιδία τότε αυτοί οι δείκτες θα μένουν αναξιοποίητοι, επομένως θα έχουμε σπάταλη χώρου. ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 11

Αναπαράσταση Δένδρων στη Μνήμη Πρόβλημα: Μείωση της σπατάλης χώρου από αχρησιμοποίητους δείκτες. Λύση: Μπορούμε να μετατρέψουμε ένα δέντρο n-αδικό(κάθε κόμβος με n παιδιά)σε ένα 2-αδικό(κάθε κόμβος με 2 παιδιά) χρησιμοποιώντας την πολιτική «Πρώτο Παιδί / Επόμενο Αδέρφι» (First Child/Next Sibling) Δηλαδή κάθε κόμβος u περιέχει 1. τα δεδομένα του κόμβου, 2. δείκτη στο αριστερότερο (πρώτο) παιδί του u, 3. δείκτη στον επί δεξιά αδελφό του u, αν υπάρχει. Αυτή η πολιτική μας επιτρέπει να μειώσουμε τον αριθμό των δεικτών ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 12

Παράδειγμα αναπαράστασης δένδρου [Normal Tree] A B Γ Δ Δένδρο Βαθμού n (n=4) Συνολικοί δείκτες: 9 nodes *4 pointers = 36 Ε Ζ Η Θ Ι [First Child/Next Sibling] Α Β Γ Δ Δένδρο Βαθμού n (n=2) Συνολικοί δείκτες: 9 nodes *2 pointers = 18 NULL Pointer Ε Ζ Η Θ Ι Next sibling ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 13

Διάσχιση Δένδρων Αν θέλουμε να επισκεφθούμε όλους τους κόμβουςενός δένδρου, μπορούμε να χρησιμοποιήσουμε ένα από τους πιο κάτω τρόπους, οι οποίοι διαφέρουν στη σειρά με την οποία εξετάζουν τους κόμβους. 1. Προθεματική Διάσχιση: (Preorder Traversal) επισκεπτόμαστε (εκτυπώνουμε) πρώτα τη ρίζα και ύστερα τα παιδιάτης. Αναδρομικά η πράξη ορίζεται ως εξής: Print_Preorder(treenode u) Print u; foreach child v of u Print_Preorder(v) 2. ΜεταθεματικήΔιάσχιση: (PostorderTraversal)επισκεπτόμαστε (εκτυπώνουμε) πρώτα τα παιδιά και ύστερα τη ρίζα του δένδρου. Αναδρομικά η πράξη ορίζεται ως εξής: Print_Postorder(treenode u) foreach child v of u Print_Postorder(v) Print u; ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 14

Παράδειγμα Διάσχισης δένδρου A B Γ Δ Ε Ζ Η Θ Ι Print_Preorder(treenode u) Print u; foreach child v of u Print_Preorder(v) Print_Postorder(treenode u) foreach child v of u Print_Postorder(v) Print u; Προθεματική Διάσχιση(Preorder) :ΑΒ Ε Γ Δ Ζ Η Θ Ι Μεταθεματική Διάσχιση(Postorder) :Ε Β Γ Ζ Η Θ Ι Δ Α ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 15

Χρήσιμες Πράξεις του ΑΤΔ Δένδρο Parent(u) επέστρεψε τον πατέρα του u Children(u) FirstChild(u) επέστρεψε τα παιδιά του u επέστρεψε το πρώτο παιδί του u RightSibling(u) επέστρεψε τον κόμβο στα δεξιά του u LeftSibling(u) IsLeaf(u) IsRoot(u) Depth(u) επέστρεψε τον κόμβο στα αριστερά του u αν το uείναι φύλλο τότε δώσε true, διαφορετικά δώσε false αν το uείναι η ρίζα του δένδρου δώσε true, διαφορετικά δώσε false δώσε το βάθος του u στο δένδρο. ΕΠΛ035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. Και Μηχ. Υπολ. 16