ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Slides:



Advertisements
Παρόμοιες παρουσιάσεις
Γραφήματα & Επίπεδα Γραφήματα
Advertisements

Συλλογές, Στοίβες και Ουρές Σε πολλές εφαρμογές μας αρκεί η αναπαράσταση ενός δυναμικού συνόλου με μια δομή δεδομένων η οποία δεν υποστηρίζει την αναζήτηση.
Δυναμικοί πίνακες Πολλές δομές δεδομένων υλοποιούνται με χρήση πινάκων
ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι
Lab 3: Sorted List ΕΠΛ231-Δομές Δεδομένων και Αλγόριθμοι18/10/2010.
Διακριτά Μαθηματικά ΙI Δυαδικά Δέντρα Αναζήτησης
Διακριτά Μαθηματικά ΙI Δέντρα
Δομές Δεδομένων - Δυαδικά Δένδρα (binary trees)
Ισορροπημένα Δένδρα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Μπορούμε να επιτύχουμε χρόνο εκτέλεσης για.
Αλγόριθμοι Ταξινόμησης
Ψηφιακά Δένδρα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Μπορούμε να χρησιμοποιήσουμε την παραπάνω αναπαράσταση.
Αλγόριθμοι και Πολυπλοκότητα
11-1 ΜΑΘΗΜΑ 12 ο Γράφοι, Διάσχιση Γράφων Υλικό από τις σημειώσεις Ν. Παπασπύρου, 2006.
Δυαδικά Δένδρα Αναζήτησης, Δένδρα AVL
Lab 6: AVL Trees 29/10/20101ΕΠΛ231 - Δομές Δεδομένων και Αλγόριθμοι.
Γραφήματα & Επίπεδα Γραφήματα
Κοντινότεροι Κοινοί Πρόγονοι α βγ θ δεζ η π ν ι κλμ ρσ τ κκπ(λ,ι)=α, κκπ(τ,σ)=ν, κκπ(λ,π)=η κκπ(π,σ)=γ, κκπ(ξ,ο)=κ ξο κκπ(ι,ξ)=β, κκπ(τ,θ)=θ, κκπ(ο,μ)=α.
1 Θεματική Ενότητα Γραφήματα & Επίπεδα Γραφήματα.
Προσεγγιστικοί Αλγόριθμοι
Δυναμική Διατήρηση Γραμμικής Διάταξης Διατηρεί μια γραμμική διάταξη δυναμικά μεταβαλλόμενης συλλογής στοιχείων. Υποστηρίζει τις λειτουργίες: Έλεγχος της.
Ισορροπημένα Δένδρα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Μπορούμε να επιτύχουμε χρόνο εκτέλεσης για.
A Balanced Tree Structure for Peer-to-Peer Networks
Δομές Αναζήτησης TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Χειριζόμαστε ένα σύνολο στοιχείων όπου το κάθε.
Ισορροπημένα Δένδρα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Μπορούμε να επιτύχουμε χρόνο εκτέλεσης για.
Ψηφιακά Δένδρα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Μπορούμε να χρησιμοποιήσουμε την παραπάνω αναπαράσταση.
Γράφοι: Προβλήματα και Αλγόριθμοι
ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι12-1 Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Ο αλγόριθμος του Prim και ο αλγόριθμος του Kruskal.
Διδάσκων: Παύλος Παυλικκάς1 Ολυμπιάδα Πληροφορικής Γράφοι – Διάσχιση.
Θεωρία Γράφων Θεμελιώσεις-Αλγόριθμοι-Εφαρμογές
Ουρά Προτεραιότητας: Heap
ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΠΛΗΡΟΦΟΡΙΚΗ
Lists– Λίστες 1. Αυτό-αναφορικές δομές Τα μέλη μίας δομής μπορεί να είναι οποιουδήποτε τύπου, ακόμα και δείκτες σε δομές του ίδιου τύπου. Χρησιμοποιώντας.
Διδάσκοντες: Σ. Ζάχος, Δ. Φωτάκης
TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Ουρά Προτεραιότητας (priority queue) Δομή δεδομένων που υποστηρίζει.
TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Ουρά Προτεραιότητας (priority queue) Δομή δεδομένων που υποστηρίζει.
Διερεύνηση γραφήματος. Ένας αλγόριθμος διερεύνησης γραφήματος επισκέπτεται τους κόμβους του γραφήματος με μια καθορισμένη στρατηγική, π.χ. κατά εύρος.
TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Ουρά Προτεραιότητας (priority queue) Δομή δεδομένων που υποστηρίζει.
Δομές Δεδομένων - Ισοζυγισμένα Δυαδικά Δένδρα (balanced binary trees)
Δομές Αναζήτησης TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Θέλουμε να υποστηρίξουμε δύο βασικές λειτουργίες:
Λεξικό, Union – Find Διδάσκοντες: Σ. Ζάχος, Δ. Φωτάκης Επιμέλεια διαφανειών: Δ. Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό Μετσόβιο.
Διερεύνηση γραφήματος. Ένας αλγόριθμος διερεύνησης γραφήματος επισκέπτεται τους κόμβους του γραφήματος με μια καθορισμένη στρατηγική, π.χ. κατά εύρος.
ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι 8-1 Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: 2-3 Δένδρα, Υλοποίηση και πράξεις Β-δένδρα B-Δένδρα.
Lab 3: Sorted List ΕΠΛ231-Δομές Δεδομένων και Αλγόριθμοι115/4/2015.
ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι
ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι13-1 Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Ο αλγόριθμος Dijkstra για εύρεση βραχυτέρων μονοπατιών.
Παράδειγμα B + -Tree Υποθέτουμε B + -Tree τάξης 3 (α=2, b=3)  Κάθε φύλλο θα έχει 2 ως 3 το πολύ στοιχεία  Κάθε εσωτερικός κόμβος θα έχει 2 ως 3 το πολύ.
1 ΤΜΗΜΑ ΜΠΕΣ Αλγόριθμοι Αναζήτησης Εργασία 1 Τυφλή Αναζήτηση.
ΠΡΟΓΡΑΜΜΑΤΙΣΤΙΚΕΣ ΤΕΧΝΙΚΕΣ Διδάσκοντες:Γιάννης Μαΐστρος Στάθης Ζάχος Νίκος Παπασπύρου
9-1 ΜΑΘΗΜΑ 9 ο Δυαδικά Δένδρα, Διάσχιση Δυαδικών Δένδρων Υλικό από τις σημειώσεις Ν. Παπασπύρου, 2006.
ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι 4-1 Στην ενότητα αυτή θα μελετηθεί η χρήση στοιβών στις εξής εφαρμογές: Αναδρομικές συναρτήσεις Ισοζυγισμός Παρενθέσεων.
Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1 Ευρετήρια.
ΛΟΓ102: Τεχνολογία Λογισμικού Ι Διδάσκων: Νίκος Παπασπύρου 1Νίκος ΠαπασπύρουΛΟΓ102:
ΠΡΟΓΡΑΜΜΑΤΙΣΤΙΚΕΣ ΤΕΧΝΙΚΕΣ Διδάσκοντες:Γιάννης Μαΐστρος Στάθης Ζάχος Νίκος Παπασπύρου
Συνδετικότητα γραφήματος (graph connectivity). α β Υπάρχει μονοπάτι μεταξύ α και β; Παραδείγματα: υπολογιστές ενός δικτύου ιστοσελίδες ισοδύναμες μεταβλητές.
Γράφημα Συνδυαστικό αντικείμενο που αποτελείται από 2 σύνολα:
Δυναμικός Κατακερματισμός
Επίλυση Προβλημάτων με Αναζήτηση
Διδάσκων: Δρ. Τσίντζα Παναγιώτα
Δένδρα.
EPL231 – Data Structures and Algorithms
Δένδρα Αναζήτησης Πολλαπλής Διακλάδωσης
Ουρά Προτεραιότητας (priority queue)
Δομές Αναζήτησης Χειριζόμαστε ένα σύνολο στοιχείων όπου το κάθε στοιχείο έχει ένα κλειδί από ολικά διατεταγμένο σύνολο Θέλουμε να υποστηρίξουμε δύο.
14η Διάλεξη Δέντρα Δυαδικής Αναζήτησης Ε. Μαρκάκης
ΣΤΟΙΧΕΙΑ ΘΕΩΡΙΑΣ ΓΡΑΦΗΜΑΤΩΝ II
(2,4) Trees 11/15/2018 8:56 PM (2,4) Δέντρα (2,4) Δέντρα.
Εξωτερική Αναζήτηση Ιεραρχία Μνήμης Υπολογιστή Εξωτερική Μνήμη
Δυναμικός Κατακερματισμός
Αναδρομή Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα:
Μεταγράφημα παρουσίασης:

ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι Δένδρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Εισαγωγή σε δενδρικές δομές δεδομένων, ορισμοί, πράξεις και αναπαράσταση στη μνήμη Δυαδικά Δένδρα και Δυαδικά Δένδρα Αναζήτησης ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι Δένδρα Στις λίστες η εύρεση κόμβου έχει χρόνο εκτέλεσης Ο(Ν), όπου N το μήκος της λίστας. Στα δένδρα τα δεδομένα είναι ‘καλύτερα’ οργανωμένα ώστε οι διαδικασίες αναζήτησης, εισαγωγής και εξαγωγής κόμβου να είναι πιο αποδοτικές. Δένδρο είναι ένα σύνολο κόμβων που συνδέονται από ακμές ή τόξα. Ορίζεται αναδρομικά ως εξής: Ένα δένδρο είναι είτε κενό είτε αποτελείται από μια ρίζα (root), δηλαδή ένα κόμβο στον οποίο δεν καταλήγουν αλλά μόνο ξεκινούν ακμές, και 0 ή περισσότερα υποδένδρα Τ1, Τ2,, …, Τk, το καθένα ξεχωριστό από τα άλλα και από τη ρίζα. Υπάρχει μια ακμή από τη ρίζα στις ρίζες των Τ1, Τ2,, …, Τk. Από κάθε κόμβο ξεκινούν 0 ή περισσότερες ακμές. Σε κάθε κόμβο εκτός της ρίζας καταλήγει μία μόνο ακμή. Στη ρίζα δεν καταλήγει καμιά ακμή. Οι κόμβοι περιέχουν δεδομένα. Οι ακμές επιβάλλουν μια ιεραρχική δομή στα δεδομένα. ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Παράδειγμα: Unix File System /usr    /maria /christos /yiannis /courses /mail /.netscape /cpl230 /cpl231 /homeworks /notes hw1 ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Παράδειγμα: Αναπαράσταση Αριθμητικών Παραστάσεων α + β  γ  ( δ + ε )   + α  β  γ + δ ε ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι Ορισμοί Όταν υπάρχει ακμή από ένα κόμβο u σε ένα κόμβο v τότε ο u είναι ο πατέρας ή ο προκάτοχος (parent) του v, και ο v είναι παιδί (child) του u.   Η ορολογία αυτή γενικεύεται ώστε να μιλούμε για προγόνους και απογόνους κόμβων. Κόμβοι που έχουν τον ίδιο προκάτοχο ονομάζονται αδέλφια. Κόμβοι που δεν έχουν παιδιά λέγονται φύλλα. Οι υπόλοιποι λέγονται εσωτερικοί. Βαθμός (degree) ενός κόμβου είναι ο αριθμός των παιδιών του. Βαθμός ενός δένδρου είναι ο μέγιστος από τους βαθμούς των κόμβων του. Δένδρα βαθμού n λέγονται n-αδικά. Δένδρα που χρησιμοποιούνται συχνά είναι τα δυαδικά (binary), τετραδικά (quadtrees), οκταδικά (octtrees). ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Βάθος και ύψος ενός δένδρου Επίπεδο ή βάθος ενός κόμβου ονομάζουμε τον αριθμό των προγόνων του + 1. π.χ. το βάθος της ρίζας ενός δένδρου είναι 1. Βάθος ενός δένδρου ονομάζουμε το μέγιστο επίπεδο κόμβων του δένδρου. Μονοπάτι ή διαδρομή (path) ενός δένδρου είναι μια ακολουθία κόμβων v1, v2,, …, vk, όπου κάθε vi είναι πατέρας του vi+1. Το μήκος του μονοπατιού v1, v2,, …, vk είναι k-1. Ύψος ενός κόμβου ονομάζουμε το μήκος του μέγιστου μονοπατιού από τον κόμβο προς κάποιο φύλλο (μετρούμε ακμές). π.χ. το ύψος οποιουδήποτε φύλλου είναι 0. Ύψος ενός δένδρου είναι το ύψος της ρίζας του δένδρου. Διατεταγμένο δένδρο ονομάζεται ένα δένδρο όταν για κάθε παιδί u κάποιου κόμβου v γνωρίζουμε αν ο u είναι το k-οστό παιδί του v. ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι Παράδειγμα 42 24 37 6 37 24 37 42 Ύψος: 0 Βάθος:1 Ύψος: 1 Βάθος: 2 Ύψος κόμβου 37: 1 Βάθος κόμβου 37: 1 Ύψος κόμβου 24: 0 Βάθος κόμβου 24: 2 Ύψος: 2 Βάθος: 3 Ύψος κόμβου 24: 1 Βάθος κόμβου 24: 2 Ύψος κόμβου 6: 0 Βάθος κόμβου 6: 3 ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

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

Αναπαράσταση Δένδρων στη Μνήμη Η πιο απλή και φυσική στρατηγική είναι η χρήση δυναμικής χορήγησης μνήμης. Κάθε κόμβος είναι ένα καταχώρημα μνήμης που αποτελείται από κάποιο αριθμό πεδίων: το πρώτο από τα οποία περιέχει τα πραγματικά δεδομένα του κόμβου (το κλειδί), και τα υπόλοιπα περιέχουν στοιχεία σχετικά με τη δομή του δένδρου, δηλαδή περιγράφουν με κάποιο τρόπο τη σχέση του συγκεκριμένου κόμβου με άλλους κόμβους του δένδρου. Για παράδειγμα, αν θέλουμε να αναπαραστήσουμε δένδρο βαθμού n κάθε κόμβος μπορεί να έχει την πιο κάτω μορφή: Info p1 p2 … pn   όπου ο pi είναι δείκτης στο i-οστό παιδί του κόμβου. ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Αναπαράσταση Δένδρων στη Μνήμη Προβλήματα αυτού του είδους αναπαράστασης είναι αν το δένδρο δεν είναι πλήρες, τότε η μνήμη δεν αξιοποιείται αποτελεσματικά. πιθανόν ο βαθμός του δένδρου να είναι άγνωστος. Λύση: κάθε κόμβος u περιέχει τα δεδομένα (κλειδί), δείκτη στο πρώτο παιδί του u, δείκτη στον επί δεξιά αδελφό του u, αν υπάρχει. Νέο πρόβλημα: Πώς μπορούμε να επισκεφθούμε όλα τα παιδιά κάποιου κόμβου u; ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Παράδειγμα αναπαράστασης δένδρου A B Γ Δ Ε Ζ Η Θ Ι Α Β Γ Δ Ε Ζ Η Θ Ι ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι Διάσχιση Δένδρων Αν θέλουμε να επισκεφθούμε όλους τους κόμβους ενός δένδρου, μπορούμε να χρησιμοποιήσουμε ένα από τους πιο κάτω τρόπους, οι οποίοι διαφέρουν στη σειρά με την οποία εξετάζουν τους κόμβους. Προθεματική Διάσχιση: (preorder traversal) επισκεπτόμαστε πρώτα τη ρίζα και ύστερα τα παιδιά της. Αναδρομικά η πράξη ορίζεται ως εξής: Print_Preorder(*treenode u) Output data at u; for each child v of u Print_Preorder(v) Μεταθεματική Διάσχιση: (postorder traversal) επισκεπτόμαστε πρώτα τα παιδιά και ύστερα τη ρίζα του δένδρου. Αναδρομικά: Print_Postorder(*treenode u) Print_Postorder(v) output data at u; ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Παράδειγμα Διάσχισης δένδρου A B Γ Δ Ε Ζ Η Θ Ι Προθεματική Διάσχιση: Μεταθεματική Διάσχιση: A B E Γ Δ Ζ Η Θ Ι E B Γ Ζ Η Θ Ι Δ A ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι Δυαδικά Δένδρα Ένα δένδρο είναι δυαδικό αν όλοι οι κόμβοι του έχουν βαθμό  2. Ορισμός: Δυαδικό δένδρο λέγεται ένα δένδρο το οποίο είτε είναι κενό, είτε αποτελείται από μια ρίζα και δύο δυαδικά υπόδενδρα, το καθένα διακριτό από το άλλο και από τη ρίζα. Αναφερόμαστε στα δύο υπόδενδρα ως το αριστερό και το δεξιό υπόδενδρο. Το ύψος ενός δυαδικού δένδρου με n κόμβους μπορεί να είναι το πολύ και το λιγότερο . Ένα δυαδικό δένδρο είναι γεμάτο (full), αν κάθε εσωτερικός του κόμβος έχει δύο παιδιά. Ένα δυαδικό δένδρο είναι τέλειο (perfect), αν είναι γεμάτο και όλα τα φύλλα έχουν το ίδιο βάθος. n – 1 lg n ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι Δυαδικά Δένδρα Ένα δυαδικό δένδρο είναι πλήρες (complete) αν έχει ύψος 0 και ένα κόμβο, έχει ύψος 1 και η ρίζα του έχει είτε δύο παιδιά είτε ένα αριστερό παιδί. έχει ύψος h και η ρίζα του έχει ένα τέλειο αριστερό υπόδενδρο ύψους h-1 και ένα πλήρες δεξιό υπόδενδρο ύψους h-1, ή ένα πλήρες αριστερό υπόδενδρο ύψους h-1 και ένα τέλειο δεξιό υπόδενδρο ύψους h-2. Παραδείγματα δυαδικών δένδρων ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι Θεώρημα Ένα γεμάτο δυαδικό (μη άδειο) δένδρο με n εσωτερικούς κόμβους, έχει n+1 φύλλα. Κάθε δυαδικό δένδρο με n κόμβους έχει n+1 null δείκτες   Απόδειξη (2) με τη μέθοδο της μαθηματικής επαγωγής: Βάση της επαγωγής: n = 0 To δένδρο αποτελείται από ένα NULL δείκτη και το ζητούμενο έπεται. Υπόθεση της επαγωγής: Έστω ότι κάθε δυαδικό δένδρο με k κόμβους, k < m, έχει k+1 NULL δείκτες. Βήμα της επαγωγής: Έστω δυαδικό δένδρο με m κόμβους. Θέλουμε να δείξουμε πως περιέχει m+1 NULL δείκτες. ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι Θεώρημα Ένα οποιοδήποτε δυαδικό δένδρο έχει την πιο κάτω μορφή: Ο αριθμός NULL δεικτών του δένδρου είναι = ο αριθμός NULL δεικτών του αριστερού υποδένδρου + ο αριθμός NULL δεικτών του δεξιού υποδένδρου = {από την υπόθεση της επαγωγής και αφού m1, m2< m} (m1+1) + (m2+ 1) = (m1+ m2+1 ) + 1 = m + 1 m1 + m2 + 1 = m m1 κόμβοι m2 κόμβοι ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Υλοποίηση Δυαδικών Δένδρων Αφού κάθε κόμβος σε ένα δυαδικό δένδρο έχει το πολύ δύο παιδιά, μπορούμε να κρατούμε δείκτες στο καθένα από αυτά. Δηλαδή, ένας κόμβος μπορεί να υλοποιηθεί ως μια εγγραφή BΤnode με τρία πεδία (παρόμοια με κόμβο διπλά συνδεδεμένης λίστας). val, όπου αποθηκεύουμε την πληροφορία του κόμβου, left, τύπου pointer, ο οποίος δείχνει το αριστερό, υπόδενδρο που ριζώνει στον συγκεκριμένο κόμβο, και right, τύπου pointer, ο οποίος δείχνει το δεξιό υπόδενδρο που ριζώνει στον συγκεκριμένο κόμβο. v Έτσι, ένα δυαδικό δένδρο υλοποιείται ως ένας δείκτης στη ρίζα του δένδρου, δηλαδή δείκτης σε εγγραφή τύπου BTnode. ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Δυαδικά Δένδρα Αναζήτησης ( Binary Search Trees) Το πιο σημαντικό πλεονέκτημα της χρήσης δυαδικών δένδρων είναι η αποδοτική αναζήτηση σε ένα σύνολο στοιχείων. Υποθέτουμε την ύπαρξη μιας σχέσης στο σύνολο των στοιχείων που επεξεργαζόμαστε, έστω τη σχέση < πάνω στο σύνολο των ακεραίων. Ένα δυαδικό δένδρο αναζήτησης (ΔΔΑ) είναι ένα δυαδικό δένδρο κάθε κόμβος u του οποίου ικανοποιεί τα εξής: τα κλειδιά του αριστερού υποδένδρου του u είναι μικρότερα από το κλειδί του u τα κλειδιά του δεξιού υποδένδρου του u είναι μεγαλύτερα από το κλειδί του u. struct BSTnode{ int val; BSTnode *left; BSTnode *right; } ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι Κτίζοντας ένα ΔΔΑ Εισαγωγή 37: Εισαγωγή 24: 37 Εισαγωγή 42: Εισαγωγή 6: Εισαγωγή 40: 24 42 Εισαγωγή 60: 6 40 60 ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι Κτίζοντας ένα ΔΔΑ Δένδρο με τα ίδια στοιχεία τοποθετημένα με διαφορετική σειρά: 60, 42, 6, 24, 37, 40. Εισαγωγή 60: 60 Εισαγωγή 42: Εισαγωγή 6: 42 Εισαγωγή 24: Εισαγωγή 37: 6 Εισαγωγή 40: 24 37 40 ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Διαδικασία Εύρεσης Στοιχείου Απλή αναδρομική στρατηγική: συγκρίνουμε το στοιχείο που μας ενδιαφέρει α με το στοιχείο της ρίζας του δένδρου β (αν υπάρχει) και αν α=β, σταματούμε, αν α<β, προχωρούμε στο αριστερό υπόδενδρο, αν α>β προχωρούμε στο δεξιό υπόδενδρο. BSTnode* Find(BSTnode* r,int n){ if (r == null) return null; else if (n < (*r).val) return Find((*r).left, n); else if (n == (*r).val) ) return r; else return Find((*r).right,n); } ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Διαδικασία Εισαγωγής Κόμβου BSTnode* InsertNode(BSTnode* r, int n){ if (r == NULL) p=(ΒSTNODE *)malloc(sizeof(BSTNODE)); (*p).val = n; (*p).left = NULL; (*p).right = NULL; return p; if (n < (*r).val)) (*r).left = InsertNode((*r).left, n); if (n > (*r).val)) (*r).right = InsertNode((*r).right, n); return r; } ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Εξαγωγή του μικρότερου κόμβου Ακολουθούμε τους αριστερούς δείκτες όσο μπορούμε, φθάνοντας στον κόμβο με το μικρότερο στοιχείο, u. Βρίσκουμε τον πατέρα v του u και αλλάζουμε τον αριστερό δείκτη του v ώστε να δείχνει στο δεξιό παιδί του u. 42 24 60 37 ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Εξαγωγή του μικρότερου κόμβου BSTnode* deleteMin(BSTnode* r){ if r!= null if ((*r).left != null) (*r).left = deleteMin((*r).left); return r; else temp = r; r = (*r).right; free temp; } ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι Διαγραφή κόμβου Για να αφαιρέσουμε ένα κλειδί i από ένα ΔΔΑ: Βρίσκουμε τον κόμβο u που περιέχει το i. Ας υποθέσουμε πως v είναι ο πατέρας του u. Αν u είναι φύλλο, τότε αλλάζουμε τον δείκτη του v που δείχνει το u, ώστε να γίνει null. Αν ο u έχει ένα παιδί, τότε αλλάζουμε τον δείκτη του v που δείχνει τον u, ώστε να δείχνει στο παιδί του u. Αν ο u έχει δύο παιδιά, αλλάζουμε το κλειδί του u ώστε να γίνει το μικρότερο από τα κλειδιά όλων των απογόνων του που έχουν κλειδιά μεγαλύτερα του i. καλούμε τη διαδικασία DeleteMin στο δεξιό παιδί του u. ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

Παράδειγμα Διαγραφής Κόμβου Αφαίρεση του στοιχείου 37:   ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι

ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι Διαγραφή Κόμβου Το κόστος κάθε διαδικασίας είναι ανάλογο του βάθους/ύψους του δένδρου. Θ(Ν) στη χειρότερη περίπτωση, Θ(log N) στη μέση περίπτωση, υποθέτοντας πως όλα τα δένδρα είναι εξίσου πιθανά. Σημειώστε πως η διαδικασία διαγραφής κόμβου που έχουμε περιγράψει αφαιρεί πάντα κόμβο δεξιού υποδένδρου. Έτσι βοηθά την ύπαρξη μιας ασυμμετρίας στη δομή των ΔΔΑ (πιο βαθιά στα αριστερά).  Ερώτημα: Μπορούμε, κατά τις εισαγωγές και εξαγωγές στοιχείων, να οργανώνουμε ένα δένδρο έτσι ώστε το ύψος του να παραμένει όσο το δυνατό πιο μικρό (τάξεως O(log n)); ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι