ΕΝΟΤΗΤΑ 5 ΥΛΟΠΟΙΗΣΗ ΛΕΞΙΚΩΝ ΜΕ ΙΣΟΖΥΓΙΣΜΕΝΑ ΔΕΝΔΡΑ

Μέγεθος: px
Εμφάνιση ξεκινά από τη σελίδα:

Download "ΕΝΟΤΗΤΑ 5 ΥΛΟΠΟΙΗΣΗ ΛΕΞΙΚΩΝ ΜΕ ΙΣΟΖΥΓΙΣΜΕΝΑ ΔΕΝΔΡΑ"

Transcript

1 ΕΝΟΤΗΤΑ ΥΛΟΠΟΙΗΣΗ ΛΕΞΙΚΩΝ ΜΕ ΙΣΟΖΥΓΙΣΜΕΝΑ ΔΕΝΔΡΑ ΗΥ24 - Παναγιώτα Φατούρου 1 Ισοζυγισµένα Δένδρα Χρονική Πολυπλοκότητα αναζήτησης σε δοµές που έχουν ήδη διδάχθει: q Στατική Μη-Ταξινοµηµένη Λίστα -> Ο(n), όπου n το πλήθος των κόµβων q Στατική Ταξινοµηµένη Λίστα -> Ο(n) q Δυναµική µη-ταξινοµηµένη λίστα -> O(n) q Δυναµική ταξινοµηµένη λίστα -> O(n) q Μη-ταξινοµηµένα Δένδρα -> O(n), όπου n το πλήθος των κόµβων q Ταξινοµηµένα Δένδρα - > O(h), όπου h το ύψος του δένδρου Τι τιµές µπορεί να πάρει το h; Γραµµική πολυπλοκότητα Αναζητούνται δοµές δεδοµένων για την υλοποίηση δυναµικών λεξικών που να παρουσιάζουν καλύτερη χρονική πολυπλοκότητα: q π.χ., όλες οι λειτουργίες να έχουν χρονική πολυπλόκοτητα Ο(logn) ΗΥ24 - Παναγιώτα Φατούρου 2 1

2 Δένδρα AVL (Adel son, Vel skii & Landis) Ένα ταξινοµηµένο δυαδικό δένδρο Τ ονοµάζεται AVL (ή ισοζυγισµένο κατ ύψος) αν και µόνο αν τα ύψη των δύο υποδένδρων κάθε κόµβου v διαφέρουν το πολύ κατά ένα. Για κάθε κόµβο v ενός δυαδικού δένδρου Τ, ορίζουµε το αριστερό ύψος του v (LeftHeight(v)) ως εξής: αν v->lc == NULL LeftHeight() v = 1 + Height( v > LC) διαφορετικά Οµοίως, ορίζουµε το δεξιό ύψος του v (ightheight(v)) ως εξής: αν v->c == NULL ightheightv () = 1 + Heightv ( > C) διαφορετικά Το LeftHeight(T) (ightheight(t)) του δένδρου ισούται µε το LeftHeight() (ightheight(), αντίστοιχα), όπου είναι ο κόµβος ρίζα του Τ. ΗΥ24 - Παναγιώτα Φατούρου 3 Δένδρα AVL Το balance (ισοζύγιο) του κόµβου v ορίζεται ως εξής: balance(v) = ightheight(v) LeftHeight(v). Σχήµα 7.1: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 1991 Σε ένα δένδρο AVL, κάθε κόµβος πρέπει να έχει balance, ή -1. Πρόταση 1 Κάθε υποδένδρο ενός δένδρου AVL είναι επίσης δένδρο AVL. Θεώρηµα Το ύψος h ενός δένδρου AVL µε n στοιχεία είναι Ο(logn). Τι µπορούµε να συµπεράνουµε για την πολυπλοκότητα της AVLTreeLookUp()? Τα δένδρα (α), (b) και (c) είναι δένδρα AVL, ενώ τα (d) και (e) δεν είναι. ΗΥ24 - Παναγιώτα Φατούρου 4 2

3 Δένδρα AVL Απόδειξη Θεωρήµατος q Αναζητούµε ένα πάνω φράγµα στο µήκος h του µακρύτερου µονοπατιού οποιουδήποτε δένδρου AVL µε n κόµβους. q Έστω ένας οποιοσδήποτε ακέραιος h. Θα εστιάσουµε στο ερώτηµα «Ποιος είναι ο µικρότερος ακέραιος n τ.ω. να υπάρχει ένα δένδρο AVL ύψους h µε n κόµβους;» q W h : σύνολο όλων των δένδρων AVL ύψους h µε ελάχιστο πλήθος κόµβων. q w h : πλήθος κόµβων σε οποιoδήποτε από αυτά τα δένδρα. q w = 1 και w 1 = 2. q Έστω ότι Τ είναι οποιοδήποτε δένδρο AVL στο W h και έστω T L και T το αριστερό και το δεξιό υποδένδρο του Τ, αντίστοιχα. ΗΥ24 - Παναγιώτα Φατούρου Δένδρα AVL Απόδειξη Θεωρήµατος q Αφού το T έχει ύψος h, είτε το T L ή το T έχει ύψος h-1 (ας υποθέσουµε χωρίς βλάβη της γενικότητας ότι το T έχει ύψος h-1). q Το T είναι δένδρο AVL ύψους h-1 και µάλιστα θα πρέπει να έχει το µικρότερο πλήθος κόµβων µεταξύ των δένδρων AVL ύψους h-1 (αφού στην αντίθετη περίπτωση, θα µπορούσε να αντικατασταθεί από κάποιο δένδρο AVL ύψους h-1 µε λιγότερους κόµβους και να οδηγηθούµε έτσι σε ένα δένδρο AVL ύψους h µε λιγότερους κόµβους από ότι το Τ, το οποίο αντιτίθεται στον ορισµό του Τ). ΗΥ24 - Παναγιώτα Φατούρου 6 3

4 Δένδρα AVL Απόδειξη Θεωρήµατος q Άρα, T W h-1. q Αφού το T είναι δένδρο AVL, το T L έχει ύψος είτε h-1 ή h-2. Εφόσον το Τ είναι δένδρο µε ελάχιστο πλήθος κόµβων µεταξύ εκείνων µε ύψος h, θα πρέπει να ισχύει T L W h-2. q Εποµένως: w h = 1 + w h-2 + w h-1 q Μπορεί να αποδειχθεί (επαγωγικά) ότι w h = F h+3-1, όπου F i είναι ο i-οστός όρος της ακολουθίας Fibonacci, για τον οποίο ισχύει ότι F i > φ i / -1, όπου φ = (1+ )/2. q Εποµένως, n w h > φ h+3 / -2. q Από την παραπάνω ανίσωση προκύπτει ότι h = Ο(logn). ΗΥ24 - Παναγιώτα Φατούρου 7 Δένδρα AVL Εισαγωγή Πως µπορούµε να υλοποιήσουµε την Insert()? Που διαφέρει από την Insert() σε δυαδικό δένδρο αναζήτησης? 1η Προσπάθεια Σχεδίασης Αλγορίθµου Εισαγωγής q Ακολουθώντας το γνωστό αλγόριθµο εισαγωγής σε δένδρο δυαδικής αναζήτησης, βρίσκουµε το µονοπάτι από τη ρίζα προς τον κατάλληλο κόµβο (έστω v) στον οποίο θα γίνει η εισαγωγή. q Υπολογίζουµε τα νέα balances για κάθε κόµβο του µονοπατιού. q Αν το balance όλων των κόµβων του µονοπατιού εξακολουθεί να είναι, ή -1, η διαδικασία εισαγωγής τερµατίζει. q Αν το balance κάποιου κόµβου αλλάζει σε +2 ή σε 2, θα πρέπει να ακολουθηθεί διαδικασία προσαρµογής του balance. Η διαδικασία αυτή θα έχει ως αποτέλεσµα το δένδρο να εξακολουθεί να είναι ταξινοµηµένο δυαδικό δένδρο µε τους ίδιους κόµβους και κλειδιά, αλλά µε όλους τους κόµβους να έχουν balance, 1, ή -1. ΗΥ24 - Παναγιώτα Φατούρου 8 4

5 Δένδρα AVL Περιστροφές Μια περιστροφή είναι µια τοπική λειτουργία σε ένα ταξινοµηµένο δένδρο η οποία διατηρεί την ιδιότητα της ταξινόµησης. Σχήµα 13.2: Cormen, Leiserson, ivest & Stein, Εισαγωγή στους Αλγορίθµους, Πανεπιστηµιακές Εκδόσεις Κρήτης, 26 Αριστερή Περιστροφή γύρω από έναν κόµβο x (ο οποίος έχει δεξιό θυγατρικό κόµβο y!= nill) q Στρέφει τους x και y κατά αντίστροφη φορά αυτής των δεικτών του ρολογιού. q Καθιστά τον y νέα ρίζα του υποδένδρου, µετατρέποντας τον x σε αριστερό παιδί του y και το αριστερό υποδένδρο του y σε δεξιό υποδένδρο του x. Σχήµα 13.3: Cormen, Leiserson, ivest & Stein, Εισαγωγή στους Αλγορίθµους, Πανεπιστηµιακές Εκδόσεις Κρήτης, 26 ΗΥ24 - Παναγιώτα Φατούρου 9 Δένδρα AVL Περιστροφές Procedure Leftotate(pointer, pointer x) { y = x->c; // ορισµός του y /* µετατροπή αριστερού υποδένδρου y σε δεξιό υποδένδρο x */ x->c = y->lc; if (y->lc!= NULL) y->lc->p = x; /* νέος πατρικός κόµβος του y γίνεται ο πρώην πατρικός κόµβος του x και αν δεν υπάρχει τέτοιος κόµβος, νέα ρίζα του δένδρου γίνεται το y */ y->p = x->p; if (x->p == NULL) { y-> LC = x; x->p = y; return y; } if (x == x->p->lc) // αν ο x είναι αριστερό παιδί του πατέρα του x->p->lc = y; else x->p->c = y; y->lc = x; // αριστερό παιδί του y γίνεται το x x->p = y; // πατέρας του x γίνεται το y } Μια δεξιά περιστροφή γίνεται µε συµµετρικό τρόπο. Χρονική Πολυπλοκότητα µιας περιστροφής; Ο(1) ΗΥ24 - Παναγιώτα Φατούρου 1

6 Δένδρα AVL Εισαγωγή Ο πρώτος κόµβος στο µονοπάτι από τον εισαχθέντα κόµβο v προς τη ρίζα, του οποίου το balance ήταν ή -1 (πριν την εισαγωγή) ονοµάζεται κρίσιµος κόµβος. Αν ο κόµβος αυτός αποκτά balance +2 ή -2 µετά την εισαγωγή, τότε πρέπει να γίνουν κατάλληλες ενέργειες ώστε να διορθωθεί το balance του. Διακρίνουµε περιπτώσεις ανάλογα µε το είδος των δύο πρώτων ακµών του µονοπατιού από τον κρίσιµο κόµβο w προς τον εισαχθέντα κόµβο v., + 2, 11 w Σχήµα 7.4: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 1991, +2 3,,, 3 7 1, +2,,, T 3 Εισαγωγή 8,, 8 ΗΥ24 - Παναγιώτα Φατούρου 11 T 1 T 2 w κρίσιµος κόµβος (w) v v w Δένδρα AVL Εισαγωγή Περίπτωση (ight-ight): Και οι δύο ακµές οδηγούν δεξιά. w q Εκτελούµε µια αριστερή περιστροφή γύρω από τον κρίσιµο κόµβο. v Παρατήρηση: Έστω x ο πατρικός κόµβος του w και έστω ότι ο w είναι, δεξιό παιδί του x. Το ύψος του w πριν την εισαγωγή και µετά την,, +2 3 περιστροφή είναι το ίδιο (στο κρίσιµος κόµβος (w) παράδειγµα h+2),,, 3 7 1, +2,,, T 3 Εισαγωγή 8,, T 1 8 T 2 v ΗΥ24 - Παναγιώτα Φατούρου 12 6

7 Δένδρα AVL Εισαγωγή Περίπτωση " Όλοι οι κόµβοι στο µονοπάτι από τον κρίσιµο κόµβο προς τη ρίζα έχουν το ίδιο balance µετά την περιστροφή µε αυτό που είχαν πριν την εισαγωγή του v στο δένδρο. x w x πριν την εισαγωγή µετά την εισαγωγή, x,,+2 3 κρίσιµος κόµβος 3 7 1, +2, πριν την εισαγωγή,,, µετά την εισαγωγή ,,, 7, 11 x Εισαγωγή 8 T,, 1,, 3 T, 2 8 v T 3 Μία περιστροφή γύρω από τον κρίσιµο κόµβο αρκεί ,,,, 2, 7 9,,, 4 8 Μετά περιστροφής,, T 1 T 2 ΗΥ24 - Παναγιώτα Φατούρου 13 T 3 Δεν χρειάζονται περιστροφές γύρω από κόµβους που βρίσκονται πιο ψηλά από τον κρίσιµο κόµβο στο µονοπάτι από τον v προς τη ρίζα. Δένδρα AVL Εισαγωγή Περίπτωση LL Περίπτωση LL: Και οι δύο ακµές οδηγούν αριστερά. q Είναι συµµετρική της περίπτωσης! q Μία δεξιά περιστροφή γύρω από τον κρίσιµο κόµβο αρκεί για να επιλυθεί το πρόβληµα µε το balance του! -1-2 C C -1 T 3 h T 3 h h h T 1 T 2 h T 1 h T 2 C T 1 T 2 h T 3 h ΗΥ24 - Παναγιώτα Φατούρου 14 7

8 Δένδρα AVL Εισαγωγή Περίπτωση L Περίπτωση L: Η πρώτη ακµή οδηγεί δεξιά και η δεύτερη αριστερά. q Απαιτούνται δύο περιστροφές, µια δεξιά περιστροφή γύρω από τον επόµενο του κρίσιµου κόµβου στο µονοπάτι που οδηγεί στον v και µια αριστερή περιστροφή γύρω από τον κρίσιµο κόµβο. πριν την εισαγωγή, µετά την εισαγωγή,,+2 3 κρίσιµος κόµβος (Α), 3 7 1, +2,,, ,,, L 7 Εισαγωγή 8 T 1,, nill 8, T 4 Σχήµα 7.: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 1991 T 2 T 3 ΗΥ24 - Παναγιώτα Φατούρου 1 Δένδρα AVL Εισαγωγή Περίπτωση L πριν την εισαγωγή µετά την εισαγωγή, +2 11,,+2 3 Περιστροφή, +2 11,+2 3 κρίσιµος κόµβος (Α) κρίσιµος κόµβος (Α), 3 7 1, +2,,, ,,, L 7 Εισαγωγή 8 T 1,, nill 8, T Περιστροφή L 1,+2 2 4,+2-1, 6 7 8,, T 2 T 3 πριν την εισαγωγή µετά την εισαγωγή, 11 ύψος πριν την εισαγωγή = ύψος µετά την εισαγωγή = 2, 3 Ίδιες περιστροφές θα πραγµατοποιούνταν αν 3 7 1, είχαµε εισαγωγή του 3 στο αρχικό δένδρο (το 2 9,-1, 6 οποίο θα ήταν αριστερό παιδί του ).,, ΗΥ24 - Παναγιώτα Φατούρου 16 8

9 Δένδρα AVL Εισαγωγή Περίπτωση L Περίπτωση L: Η πρώτη ακµή οδηγεί αριστερά και η δεύτερη δεξιά. q Είναι συµµετρική της περιπτώσεως L. q Απαιτούνται δύο περιστροφές, µια αριστερή περιστροφή γύρω από τον επόµενο του κρίσιµου κόµβου στο µονοπάτι που οδηγεί στον v και µια δεξιά περιστροφή γύρω από τον κρίσιµο κόµβο. Άσκηση για το σπίτι Φτιάξτε τα αντίστοιχα συµµετρικά σχήµατα εκείνων που παρουσιάστηκαν στις δύο τελευταίες διαφάνειες και µελετήστε τις ενέργειες που πρέπει να πραγµατοποιηθούν στην περίπτωση L. ΗΥ24 - Παναγιώτα Φατούρου 17 Δένδρα AVL Περιστροφές κατά την Εισαγωγή Παρατήρηση n Οι περιστροφές γίνονται γύρω από το πολύ δύο κόµβους στο δένδρο ανάλογα µε την περίπτωση που πρέπει να εφαρµοστεί: µία περιστροφή γύρω από τον κρίσιµο κόµβο για τις περιπτώσεις LL, δύο περιστροφές, η πρώτη γύρω από τον επόµενο του κρίσιµου κόµβου στο µονοπάτι που ακολουθήθηκε κατά την τοποθέτηση του εισαχθέντα κόµβου και η δεύτερη γύρω από τον κρίσιµο κόµβο, για τις περιπτώσεις L, L ΗΥ24 - Παναγιώτα Φατούρου 18 9

10 Δένδρα AVL Εισαγωγή Περιπτώσεις που δεν απαιτούν περιστροφές, 11,, 3 κρίσιµος κόµβος 3 7 1,,,,, -1, ,, 7 38 Εισαγωγή 38,,,, -1 11,, ,,,, 9, Εισαγωγή 9 Σχήµα 7.3: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 1991 ΗΥ24 - Παναγιώτα Φατούρου 19 Εισαγωγές κόµβων σε AVL δένδρο Παράδειγµα Διαδοχικές εισαγωγές των κλειδιών µε τιµές 9, 71, 1, 4, 12,, 19, 2 και 6. κρίσιµος κόµβος L L κρίσιµος κόµβος -2 L L ΗΥ24 - Παναγιώτα Φατούρου 2 1

11 Εισαγωγές κόµβων σε AVL δένδρο Παράδειγµα Διαδοχικές εισαγωγές των κλειδιών µε τιµές 9, 71, 1, 4, 12,, 19, 2 και L κρίσιµος κόµβος κρίσιµος κόµβος κρίσιµος κόµβος ΗΥ24 - Παναγιώτα Φατούρου 21 Δένδρα AVL Εισαγωγή - Παρατηρήσεις q Κάθε κόµβος στο µονοπάτι από τον εισαχθέντα κόµβο v µέχρι τον κρίσιµο κόµβο w είχε balance πριν την εισαγωγή. Άρα, θα έχει balance ή 1 µετά την εισαγωγή. Τι καθορίζει το αν κάποιος τέτοιος κόµβος θα έχει balance ή 1; Το αν η πρώτη ακµή στο µονοπάτι από τον κόµβο αυτό προς τον εισαχθέντα κόµβο οδηγεί αριστερά ή δεξιά. q To balance του κρίσιµου κόµβου w γίνεται είτε ή +2 (ή 2, αντίστοιχα) µετά την τοποθέτηση του νέου κόµβου στην κατάλληλη θέση στο δένδρο. Γιατί; Πότε το balance γίνεται και πότε +2 (ή 2); Αν το balance ήταν (-1) και η πρώτη ακµή στο µονοπάτι από τον w στον v οδηγεί δεξιά (αριστερά, αντίστοιχα), ο w θα έχει balance +2 (-2, αντίστοιχα) µετά την τοποθέτηση του v, ενώ αν το µονοπάτι οδηγεί αριστερά (δεξιά, αντίστοιχα), τότε ο w θα έχει balance µετά την τοποθέτηση του v. ΗΥ24 - Παναγιώτα Φατούρου 22 11

12 Δένδρα AVL Εισαγωγή - Παρατηρήσεις q Καθώς η αναζήτηση του πατρικού κόµβου του v εξελίσσεται, αρκεί να αποθηκεύεται ο τελευταίος κόµβος µε balance ή -1 στο µονοπάτι που ακολουθείται. q Μετά την τοποθέτηση του v στο δένδρο (και πριν τις περιστροφές), ξεκινώντας από τον κρίσιµο κόµβο w µπορεί να ακολουθηθεί και πάλι το ίδιο µονοπάτι προς τον εισερχόµενο κόµβο ώστε να διορθωθούν τα balances. Γιατί µπορούµε να βρούµε και πάλι αυτό το µονοπάτι? Ακολουθούµε την ίδια διαδικασία αναζήτησης (ξεκινώντας από τον w), δηλαδή αν το κλειδί του προς εισαγωγή κόµβου είναι µικρότερο από εκείνο του τρέχοντος ο επόµενος κόµβος στο µονοπάτι είναι στα αριστερά του τρέχοντος, ενώ διαφορετικά στα δεξιά. Πως διορθώνουµε τα balances? Έστω ένας οποιοσδήποτε κόµβος x στο µονοπάτι από τον w στον v. Ο κόµβος αυτός είχε balance. Αν η πρώτη ακµή στο µονοπάτι από τον x στον v οδηγεί αριστερά του x, τότε το balance του x γίνεται -1, διαφορετικά η νέα τιµή του balance θα είναι. ΗΥ24 - Παναγιώτα Φατούρου 23 Δένδρα AVL Εισαγωγή - Πολυπλοκότητα Ποια είναι η πολυπλοκότητα της AVLInsert()? n Ο(ύψος δένδρου). n Θεώρηµα ύψος δένδρου AVL = O(logn) Χρονική Πολυπλοκότητα εισαγωγής = O(logn) ΗΥ24 - Παναγιώτα Φατούρου 24 12

13 Δένδρα AVL Διαγραφή Ακολουθούµε το γνωστό αλγόριθµο διαγραφής σε ταξινοµηµένο δένδρο: 1) Διαγραφή του ίδιου του κόµβου v αν είναι φύλλο. 2) Αντικατάστασή του από το παιδί του αν έχει µόνο ένα παιδί. 3) Αντικατάστασή του από τον επόµενό του στην ενδο-διατεταγµένη διάταξη αν έχει δύο παιδιά. Σχήµα 7.6: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 1991 (α) Αρχικό δένδρο, (b) Διαγραφή του Β, (c) Διαγραφή του F, (d) Διαγραφή του M, (e) Διαγραφή του Balance Αν 1) ή 2), το balance του γονικού κόµβου w του v αλλάζει. Αν 3), το balance του γονικού κόµβου w του εποµένου του v στην ενδοδιατεταγµένη διάσχιση αλλάζει. ΗΥ24 - Παναγιώτα Φατούρου 2 Δένδρα AVL Αλγόριθµος Διαγραφής 1. Εξετάζουµε όλο το µονοπάτι (ας το συµβολίσουµε µε P1) από τον w ως τη ρίζα και για κάθε κόµβο του µονοπατιού αυτού που έχει balance +2 ή -2 µετά τη διαγραφή, ίσως χρειαστεί να γίνουν περιστροφές. 2. Έστω u ο πρώτος τέτοιος κόµβος στο P1. Β Α C Ε H F J G I K D L w,u Β +2 C Ε H F J D G I K L ΗΥ24 - Παναγιώτα Φατούρου 26 13

14 Δένδρα AVL Αλγόριθµος Διαγραφής 3. Καθορίζουµε το µονοπάτι P2 µε το µεγαλύτερο µήκος από τον u προς οποιοδήποτε φύλλο του υποδένδρου του και εξετάζουµε τις δύο πρώτες ακµές σε αυτό το µονοπάτι. q Αν LL (ή ) πραγµατοποιούµε µια περιστροφή (L) γύρω από τον u. q Αν L (ή L) πραγµατοποιούµε δύο περιστροφές, την πρώτη τύπου (L) γύρω από τον επόµενο του u στο µονοπάτι P2 και τη δεύτερη τύπου L () γύρω από τον u. w,u Β C +2 D Ε F H G I J K L 4. Επαναπροσδιορίζουµε balances κόµβων στο P1 & αν εξακολουθούν να υπάρχουν κόµβοι µε µη-επιτρεπτό balance σε αυτό: q Θέτουµε u = πρώτος κόµβος στο P1 µε µη επιτρεπτό balance; q Πηγαίνουµε στο Βήµα 3; ΗΥ24 - Παναγιώτα Φατούρου 27 B Παράδειγµα Διαγραφής που Οδηγεί σε Πολλαπλές Περιστροφές w,u Β +2 C D C D νέος u +2 Ε Ε F H G F H G I I J J K K Κόµβος µε µη-επιτρεπτό balance Μακρύτερο µονοπάτι από αυτόν προς οποιοδήποτε φύλλο τύπου µία περιστροφή τύπου L γύρω από τον κόµβο Κόµβος µε µη-επιτρεπτό balance Μακρύτερο µονοπάτι από αυτόν προς οποιοδήποτε φύλλο τύπου µία περιστροφή τύπου L H Αν υπάρχουν περισσότερα του ενός µονοπάτια ίδιου µήκους και το µήκος αυτό είναι B D το µεγαλύτερο, µπορεί να γίνει επιλογή εκείνου του µονοπατιού που οδηγεί στις λιγότερες και πιο απλές περιστροφές! ΗΥ24 - Παναγιώτα Φατούρου 28 C E F I G J K 14

15 Δένδρα AVL Διαγραφή Σχήµα.3: I. Μανωλόπουλος, Δοµές Δεδοµένων, Μια προσέγγιση µε την Pascal, Εκδόσεις Art of Text. κρίσιµος κόµβος Παράδειγµα Διαδοχική διαγραφή των κλειδιών 12, 71, 2, 1, 19, 4, και 6. Aντικατάσταση από 1 και µια αριστερή περιστροφή γύρω από το 1 ΗΥ24 - Παναγιώτα Φατούρου 29 Δένδρα AVL Διαγραφή - Πολυπλοκότητα Ποια είναι η πολυπλοκότητα της AVLDelete()? Ο(ύψος δένδρου) για τους ακόλουθους λόγους: q Για τη διαγραφή του κόµβου το κόστος είναι Ο(ύψος δένδρου). q Για κάθε κόµβο u στο P1, θα γίνει εύρεση των δύο πρώτων ακµών του µονοπατιού που καθορίζει το ύψος του u (βάσει του balance του u και του balance του εποµένου του u στο µοναπάτι). q Θα γίνουν Ο(ύψος δένδρου) περιστροφές και κάθε µια κοστίζει Ο(1). q Τα balances αλλάζουν µόνο για τους κόµβους του P1 και τους κόµβους που «εµπλέκονται» στις περιστροφές. Θεώρηµα ύψος δένδρου AVL = O(logn) Χρονική Πολυπλοκότητα = O(logn) ΗΥ24 - Παναγιώτα Φατούρου 3 1

16 2-3 Δένδρα Ιδέα: Το δένδρο είναι τέλεια εξισορροπηµένο (όλα τα φύλλα έχουν το ίδιο βάθος) αλλά δεν είναι δυαδικό. q Σε ένα 2-3 δένδρο ένας κόµβος που δεν είναι φύλλο έχει δύο παιδιά και σε αυτόν αποθηκεύεται ένα Σχήµα 7.7: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 1991 στοιχείο του συνόλου (ένας τέτοιος κόµβος λέγεται 2-κόµβος), ή έχει τρία παιδιά και σε αυτόν αποθηκεύονται δύο στοιχεία του συνόλου (τότε ο κόµβος λέγεται 3-κόµβος). q Κάθε φύλλο που αποθηκεύει ένα στοιχείο του συνόλου είναι 2- κόµβος, ενώ κάθε φύλλο που αποθηκεύει δύο στοιχεία του συνόλου είναι 3-κόµβος. q Με κατάλληλη διευθέτηση κόµβων και των δύο ειδών, µπορούµε να φτιάξουµε δένδρο στο οποίο όλα τα φύλλα έχουν το ίδιο βάθος και το οποίο αποθηκεύει οποιοδήποτε επιθυµητό πλήθος κλειδιών. ΗΥ24 - Παναγιώτα Φατούρου 31 Ιδιότητες 2-3 Δένδρων 1. Όλα τα φύλλα έχουν το ίδιο βάθος και αποθηκεύουν 1 ή 2 στοιχεία. 2. Κάθε εσωτερικός κόµβος: q είτε αποθηκεύει ένα στοιχείο και έχει δύο παιδιά, q ή αποθηκεύει δύο στοιχεία και έχει τρία παιδιά. 3. Το δένδρο είναι ταξινοµηµένο. ΗΥ24 - Παναγιώτα Φατούρου 32 16

17 2-3 Δένδρα Ένα 2-3 δένδρο είναι ταξινοµηµένο αν για κάθε κόµβο v ισχύουν τα εξής: q Αν ο v είναι 2-κόµβος, τα κλειδιά όλων των στοιχείων που βρίσκονται στο αριστερό υποδένδρο του v είναι µικρότερα από το κλειδί του v, ενώ εκείνα των στοιχείων που βρίσκονται στο δεξί υποδένδρο του v είναι µεγαλύτερα από εκείνα του v. q Αν ο v είναι 3-κόµβος, το κλειδί (έστω Κ 1 ) του πρώτου στοιχείου του v είναι µικρότερο από το κλειδί (έστω K 2 ) του δεύτερου στοιχείου του v. Επίσης, τα κλειδιά όλων των στοιχείων στο πρώτο υποδένδρο του v είναι µικρότερα από K 1, τα κλειδιά όλων των στοιχείων στο δεύτερο υποδένδρο του v είναι µεταξύ του Κ 1 και του Κ 2, ενώ τα κλειδιά του τρίτου υποδένδρου του v είναι µεγαλύτερα από K 2. ΗΥ24 - Παναγιώτα Φατούρου Δένδρα Μεταξύ όλων των 2-3 δένδρων ύψους h, ποιο είναι εκείνο µε τους λιγότερους κόµβους; Εκείνο του οποίου όλοι οι εσωτερικοί κόµβοι είναι 2-κόµβοι. Ποιο είναι το ύψος αυτού του δένδρου? log 2 n Μεταξύ όλων των 2-3 δένδρων ύψους h, ποιο είναι εκείνο µε τους περισσότερους κόµβους; Εκείνο του οποίου όλοι οι εσωτερικοί κόµβοι είναι 3-κόµβοι. Ποιο είναι το ύψος αυτού του δένδρου? log 3 n Πως θα υλοποιήσουµε την LookUp() σε ένα 2-3 δένδρο? Το δένδρο είναι ταξινοµηµένο. Το ύψος ενός 2-3 δένδρου µε n κόµβους είναι Θ(logn). Πολυπλοκότητα LookUp; O(logn) ΗΥ24 - Παναγιώτα Φατούρου 34 17

18 2-3 Δένδρα - Εισαγωγή Σχήµα 7.8: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, Εύρεση του φύλλου w στο οποίο θα έπρεπε σύµφωνα µε την ιδιότητα της ταξινόµησης να εισαχθεί το νέο στοιχείο. 2. Διατήρηση των κόµβων του µονοπατιού που ακολουθήθηκε σε στοίβα. 3. Αν το w είναι 2-κόµβος, προσθήκη του νέου στοιχείου στο w και τερµατισµός. ΗΥ24 - Παναγιώτα Φατούρου Δένδρα Εισαγωγή Μη επιτρεπτός κόµβος Μη επιτρεπτός κόµβος 4. Αν το w είναι 3-κόµβος, Παράδειγµα: Εισαγωγή Ο µετατρέπεται σε κόµβο που w Μη επιτρεπτός κόµβος πρέπει να αποθηκεύσει 3 στοιχεία το οποίο είναι µη επιτρεπτό. Αντικαθιστούµε το w µε δύο 2-κόµβους, έναν που αποθηκεύει το 1ο και έναν που αποθηκεύει το 3ο στοιχείο του w και το µεσαίο στοιχείο του w µεταφέρεται στον πατρικό του κόµβο. Αν δεν υπάρχει πατρικός κόµβος πηγαίνουµε στο βήµα 6.. Αν ο πατρικός κόµβος είναι 2-κόµβος, µετατρέπεται σε 3-κόµβο και ο αλγόριθµος τερµατίζει. Διαφορετικά, θέτουµε w = <πατρικός κόµβος του w> και επιστρέφουµε στο βήµα Η διαδικασία αυτή επαναλαµβάνεται µέχρι να βρούµε χώρο για το κλειδί σε κάποιο κόµβο στο µονοπάτι προς τη ρίζα ή να φτάσουµε στη ρίζα. Αν συµβεί το δεύτερο, η ρίζα χωρίζεται σε 2 κόµβους και ένας νέος κόµβος που αποτελεί τον πατρικό κόµβο αυτών των δύο κόµβων αποθηκεύει το µεσαίο στοιχείο που θα έπρεπε να αποθηκευθεί στη ρίζα. Έτσι, το ύψος του δένδρου αυξάνεται κατά 1. w ΗΥ24 - Παναγιώτα Φατούρου 36 w 18

19 2-3 Δένδρα - Διαγραφή Μπορεί να προκύψει το αντίστροφο πρόβληµα: µετά τη διαγραφή, κάποιος κόµβος µπορεί να έχει ένα µόνο παιδί. µη επιτρεπτός κόµβος Παράδειγµα Διαγραφή Ε ΗΥ24- Παναγιώτα Φατούρου ΗΥ24 - Παναγιώτα Φατούρου Δένδρα - Διαγραφή Ν Ν 1. Αν το προς διαγραφή κλειδί Κ περιέχεται σε κόµβο φύλλο, το διαγράφουµε. Διαφορετικά, το κλειδί (έστω Κ ) που είναι επόµενο του K στην ενδο-διατεταγµένη διάσχιση περιέχεται σε φύλλο, οπότε Ν Ν αντικαθιστούµε το Κ µε το Κ και διαγράφουµε το Κ. 2. Έστω Ν ο κόµβος από τον οποίο διαγράφεται το κλειδί. Αν ο Ν εξακολουθεί να έχει ένα κλειδί, ο αλγόριθµος τερµατίζει. 3. Αν ο Ν είναι η ρίζα, τον διαγράφουµε. Σε αυτή την περίπτωση, ο Ν µπορεί να έχει ένα ή κανένα παιδί. Αν δεν έχει κανένα παιδί, το δένδρο µετά τη διαγραφή είναι άδειο. Διαφορετικά, το παιδί του Ν είναι η νέα ρίζα του δένδρου. S S Σχήµα 7.8: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 1991 ΗΥ24 - Παναγιώτα Φατούρου 38 19

20 2-3 Δένδρα - Διαγραφή 3. Διαφορετικά, ο Ν έχει τουλάχιστον έναν αδελφικό κόµβο. Έστω Ν ένας οποιοσδήποτε αδελφικός κόµβος του Ν. Έστω P ο πατέρας των Ν, Ν και έστω ότι S είναι το κλειδί του P που χωρίζει τα δύο υπο-δένδρα (που οδηγούν από τον P στους Ν και Ν ). Ν Ν a. Ο Ν είναι 3-κόµβος ακριβώς στα αριστερά (ακριβώς στα δεξιά) του Ν. Μετακινούµε το S στο Ν και αντικαθιστούµε το S στον πατέρα του µε το δεξιότερο (αριστερότερο) κλειδί του Ν. Αν οι Ν και Ν είναι εσωτερικοί κόµβοι, µετατρέπουµε το δεξιότερο (αριστερότερο) υποδένδρο του Ν σε αριστερότερο (δεξιότερο) υποδένδρο του Ν. Οι Ν, Ν έχουν πλέον ένα κλειδί ο καθένας και ο αλγόριθµος τερµατίζει. b. Ο Ν είναι 2-κόµβος. Συνενώνουµε το S και το κλειδί του Ν σε έναν νέο 3-κόµβο, ο οποίος αντικαθιστά τους Ν, Ν και απoτελεί το µοναδικό παιδί του P (ο οποίος αποµένει τώρα χωρίς κλειδί). Θέτουµε Ν = P και επαναλαµβάνουµε από το βήµα 3. S Ν Ν S ΗΥ24 - Παναγιώτα Φατούρου Δένδρα - Διαγραφή Ένα ακόµη παράδειγµα S N S N N H L B,D J M N N H L B,D J M Πολυπλοκότητα Insert(); Πολυπλοκότητα Delete(); Πολυπλοκότητα LookUp(); Ο(logn) Ο(logn) Ο(logn) ΗΥ24 - Παναγιώτα Φατούρου 4 2

21 Κοκκινόµαυρα Δένδρα Σχήµα 13.1(α): Cormen, Leiserson, ivest & Stein, Εισαγωγή στους Αλγορίθµους, Πανεπιστηµιακές Εκδόσεις Κρήτης, 26 q Ένα κοκκινόµαυρο δένδρο είναι ένα ταξινοµηµένο δυαδικό δένδρο, στο οποίο κάθε κόµβος περιέχει ένα επιπλέον στοιχείο πληροφορίας, το χρώµα του, το οποίο µπορεί να είναι είτε µαύρο ή κόκκινο. q Αν κάποιο παιδί κάποιου κόµβου δεν υφίσταται, ο αντίστοιχος δείκτης είναι nill. Θεωρούµε ότι δείκτες µε τιµή nill είναι δείκτες προς εξωτερικούς κόµβους (φύλλα) του δυαδικού δένδρου, ενώ οι συνήθεις κόµβοι που αποθηκεύουν κλειδιά αποτελούν τους εσωτερικούς κόµβους του δένδρου. ΗΥ24 - Παναγιώτα Φατούρου 41 Ιδιότητες Κοκκινόµαυρων Δένδρων 1. Κάθε κόµβος έχει είτε κόκκινο είτε µαύρο χρώµα. 2. Το χρώµα της ρίζας είναι πάντα µαύρο. 3. Κάθε NILL κόµβος έχει µαύρο χρώµα. 4. Αν ένας κόµβος έχει κόκκινο χρώµα, τότε και τα δύο παιδιά του έχουν µαύρο χρώµα.. Κάθε µονοπάτι από οποιονδήποτε κόµβο προς οποιοδήποτε εξωτερικό κόµβο φύλλο που είναι απόγονός του περιέχει το ίδιο πλήθος µαύρων κόµβων. ΗΥ24 - Παναγιώτα Φατούρου 42 21

22 Ύψος Κοκκινόµαυρου Δένδρου Μαύρο ύψος bh(v) κόµβου v Πλήθος µαύρων κόµβων σε κάθε µονοπάτι από τον κόµβο v σε οποιοδήποτε εξωτερικό κόµβο nill του υποδένδρου του, χωρίς να συµπεριλαµβάνουµε τον v. Πρόταση: Ένα κόκκινο µαύρο δένδρο µε n εσωτερικούςκόµβους έχει ύψος το πολύ 2log(n). Διαίσθηση: Τουλάχιστον οι µισοί κόµβοι σε κάθε µονοπάτι από τη ρίζα σε φύλλο είναι µαύροι. Γιατί; ΗΥ24 - Παναγιώτα Φατούρου 43 Ύψος Κοκκινόµαυρου Δένδρου Απόδειξη Αποδεικνύουµε επαγωγικά ότι το υπο-δένδρο µε ρίζα κάποιο κόµβο v περιέχει τουλάχιστον 2 bh(v) -1 εσωτερικούς κόµβους (η επαγωγή ως προς το ύψος του v). Βάση επαγωγής: αν ο v έχει ύψος τότε είναι φύλλο (δηλαδή εξωτερικός κόµβος), οπότε ο αριθµός των εσωτερικών κόµβων στο υποδένδρο που εκφύεται από τον v είναι, όπως απαιτείται. Επαγωγική Υπόθεση: Δοθέντος ενός οποιουδήποτε κόµβου v, υποθέτουµε ότι ο ισχυρισµός ισχύει για τα παιδιά του v. ΗΥ24 - Παναγιώτα Φατούρου 44 22

23 Ύψος Κοκκινόµαυρου Δένδρου Απόδειξη (συνέχεια) Επαγωγικό Βήµα: Αποδεικνύουµε τον ισχυρισµό για τον κόµβο v. q Έστω w ένα οποιοδήποτε παιδί του v. Τότε, bh(w) bh(v) 1 (αν ο w είναι κόκκινος τότε bh(w) = bh(v), ενώ αν ο w είναι µαύρος τότε bh(w) bh(v) -1). q Αφού το ύψος του w είναι πιο µικρό από εκείνο του v, από επαγωγική υπόθεση, το υποδένδρο που εκφύεται από τον w έχει 2 bh(w) -1 2 bh(v)-1-1 εσωτερικούς κόµβους. q Άρα, το υποδένδρο που εκφύεται από τον v έχει τουλάχιστον 2* (2 bh(v)-1-1 ) + 1 = 2 bh(v) -1 εσωτερικούς κόµβους, όπως απαιτείται. Άρα, το υπο-δένδρο που εκφύεται από οποιονδήποτε κόµβο v περιέχει τουλάχιστον 2 bh(v) -1 εσωτερικούς κόµβους. (1) Έστω h το ύψος του δένδρου και r η ρίζα. Είναι bh(r) h/2, αφού βάσει της ιδιότητας 4, σε οποιοδήποτε µονοπάτι από τη ρίζα προς οποιονδήποτε εξωτερικό κόµβο, τουλάχιστον οι µισοί κόµβο (εξαιρουµένης της ίδιας της ρίζας) θα πρέπει να είναι µαύροι. Πως υλοποιείται η LookUp(); Άρα, από (1), n 2 h/2-1 h 2log(n). Ποια είναι η πολυπλοκότητα της; ΗΥ24 - Παναγιώτα Φατούρου 4 Κοκκινόµαυρα Δένδρα - Εισαγωγή Αλγόριθµος q Εισαγωγή του νέου στοιχείου µε τον ίδιο τρόπο όπως σε ταξινοµηµένο δυαδικό δένδρο. Το µονοπάτι που ακολουθείται για την εισαγωγή του νέου κόµβου αποθηκεύεται σε στοίβα. q Ο νέος κόµβος χαρακτηρίζεται κόκκινος. q Αν οι ιδιότητες χρωµατισµού εξακολουθούν να ισχύουν, ο αλγόριθµοςτερµατίζεται. Διαφορετικά, εκτελούνται ενέργειες που αποσκοπούν στην αποκατάσταση των ιδιοτήτων του δένδρου (οι οποίες περιγράφονται στη συνέχεια). Για να απαιτείται η εκτέλεση ενεργειών αποκατάστασης του δένδρου θα πρέπει: Ο πατρικός κόµβος του νέο-εισαχθέντα κόµβου να είναι κόκκινος. Γιατί; Ο πατρικός αυτός κόµβος δεν µπορεί να είναι η ρίζα. Ο παππούς του νέο-εισαχθέντα κόµβου να είναι µαύρος. Γιατί; ΗΥ24 - Παναγιώτα Φατούρου 46 23

24 Κοκκινόµαυρα Δένδρα - Εισαγωγή Περιγραφή Ενεργειών Αποκατάστασης Υποθέτουµε ότι ο πατέρας του x είναι αριστερό παιδί του παππού του x (η αντίθετη περίπτωση είναι συµµετρική). Αν ο x και ο πατέρας του x είναι κόκκινοι, απαιτούνται ενέργειες αποκατάστασης. Περίπτωση 1: Ο αδελφικός κόµβος y του πατέρα του x είναι κόκκινος. Τότε, αλλάζουµε το χρώµα του πατέρα του x και του αδελφικού του κόµβου y σε µαύρο και το χρώµα του παππού του x σε κόκκινο. Εκτελούµε την εντολή x = παππούς του x. Επαναλαµβάνουµε ξεκινώντας από το Βήµα 1. Σχήµα 13.: Cormen, Leiserson, ivest & Stein, Εισαγωγή στους Αλγορίθµους, Πανεπιστηµιακές Εκδόσεις Κρήτης, 26 ΗΥ24 - Παναγιώτα Φατούρου 47 Κοκκινόµαυρα Δένδρα - Εισαγωγή Περιγραφή Ενεργειών Αποκατάστασης (συνέχεια) Περίπτωση 2: Ο y (αδελφικός κόµβος του πατέρα του x) είναι µαύρος και ο x είναι δεξί παιδί του πατέρα του. Ανάγουµε την περίπτωση αυτή στην περίπτωση 3 µε την εκτέλεση µιας αριστερής περιστροφής γύρω από τον πατέρα του x. (Η περίπτωση που ο x είναι αριστερό παιδί του πατέρα του είναι συµµετρική). Περίπτωση 3: Ο x είναι αριστερό παιδί του πατέρα του. Το χρώµα του πατέρα του x αλλάζει σε µαύρο και του παππού σε κόκκινο. Εκτελείται µια δεξιά περιστροφή γύρω από τον παππού του x. Σχήµα 13.6: Cormen, Leiserson, ivest & Stein, Εισαγωγή στους Αλγορίθµους, Πανεπιστηµιακές Εκδόσεις Κρήτης, 26 ΗΥ24 - Παναγιώτα Φατούρου 48 24

25 Κοκκινόµαυρα Δένδρα Εισαγωγή Κάποιες από τις Συµµετρικές Περιπτώσεις νέο x y y x y y νέο x x Περίπτωση 1: Ο αδελφικός κόµβος y του πατρικού κόµβου του x είναι κόκκινος. (Συµµετρική περίπτωση που ο πατρικός κόµβος του x είναι δεξιό παιδί του παππού του x.) ΗΥ24 - Παναγιώτα Φατούρου 49 Κοκκινόµαυρα Δένδρα Εισαγωγή Κάποιες από τις Συµµετρικές Περιπτώσεις a Περίπτωση 2 a Περίπτωση 3 x δ β x a β γ δ β γ γ δ Περίπτωση 2: Ο y (αδελφικός κόµβος του πατέρα του x) είναι µαύρος και ο x είναι αριστερό παιδί του πατέρα του. Ανάγουµε την περίπτωση αυτή στην περίπτωση 3 µε την εκτέλεση µιας δεξιάς περιστροφής. Περίπτωση 3: Ο x είναι δεξιό παιδί του πατέρα του. Το χρώµα του πατέρα του x αλλάζει σε µαύρο και του παππού σε κόκκινο. Εκτελείται µια αριστερή περιστροφή. ΗΥ24 - Παναγιώτα Φατούρου 2

26 Κοκκινόµαυρα Δένδρα Εισαγωγή - Ψευδοκώδικας edblacktree-insert(pointer, Key k) { /* Ο είναι δείκτης στη ρίζα του δένδρου και το K είναι το προς-εισαγωγή κλειδί. Θεωρώ ότι το δένδρο είναι διπλά συνδεδεµένο */ } y = nill; z = ; while (z!= null) { // έχω αγνοήσει τους ελέγχους για το αν το κλειδί K βρίσκεται ήδη στο δένδρο y = z; // οι οποίοι χρειάζονται if (K < z->key) z = z->lc; else z = z->c; } x = newcell(); x->key = K; x->lc = x->c = null; x->color = ED; x->p = y; if (y == null) (κάνε το x ρίζα του δένδρου); else if (x->key < y->key) y->lc = x; // τοποθέτηση του x ως else y->rc = x; ColorPropertiesInsert(,x) // κατάλληλου παιδιού του y ΗΥ24 - Παναγιώτα Φατούρου 1 (1) Κοκκινόµαυρα Δένδρα Εισαγωγή ColorPropertiesInsert(pointer, pointer x) { while (x->p->color == ED) { //αν το χρώµα του πατέρα του x είναι επίσης κόκκινο if (x->p == x->p->p->lc) { // αν o πατέρας του x είναι αριστερό παιδί του παππού του x y = x->p->p->c; // o y είναι ο αδελφικός κόµβος του πατέρα του x if (y->color == ED) { x->p->color = BLACK; // πατέρας και αδελφικός κόµβος πατέρα y->color = BLACK; // γίνονται και οι δυο µαύροι x->p->p->color = ED; // ο παππούς γίνεται κόκκινος x = x->p->p; // (νέο x = παππούς x); και επαναλαµβάνουµε } else { if (x == x->p->c) { // o x είναι δεξιό παιδί του πατέρα του Περίπτωση 2 x = x->p; // ο πατέρας του x θα παίξει το ρόλο του x (δείτε σχήµατα) Leftotate(, x); // αριστερή περιστροφή γύρω από τον πατέρα του x } x->p->color = BLACK; x->p->p->color = ED; ightotate(, x->p->p); } } else ( (1) µε εναλλαγή του LC µε C και το αντίστροφο, καθώς και του Leftotate µε ightotate και το αντίστροφο); } } ΗΥ24 - Παναγιώτα Φατούρου 2 26

27 Κοκκινόµαυρα Δένδρα Εισαγωγή Παράδειγµα Ποια είναι η χρονική πολυπλοκότητα της BInsert()? Σχήµα 13.4: Cormen, Leiserson, ivest & Stein, Εισαγωγή στους Αλγορίθµους, Πανεπιστηµιακές Εκδόσεις Κρήτης, 26 ΗΥ24 - Παναγιώτα Φατούρου 3 Κοκκινόµαυρα Δένδρα Διαγραφή q Η διαγραφή γίνεται µε παρόµοιο τρόπο όπως σε ταξινοµηµένο δυαδικό δένδρο και στη συνέχεια ελέγχεται αν οι ιδιότητες των κοκκινόµαυρων δένδρων ισχύουν ή όχι και γίνονται κατάλληλες ενέργειες αν απαιτούνται. q Έστω y ο κόµβος που θα διαγραφεί από το δένδρο. q Αν το χρώµα του y είναι κόκκινο, ο y διαγράφεται και ο αλγόριθµος τερµατίζει. q Γιατί δεν προκύπτει πρόβληµα µε τις ιδιότητες χρωµατισµού του δένδρου σε αυτή την περίπτωση? Δεν υπάρχουν κόµβοι των οποίων το µαύρο ύψος να έχει µεταβληθεί στο δένδρο Δεν έχει πραγµατοποιηθεί καµία απευθείας σύνδεση µεταξύ δύο κόκκινων κόµβων Δεδοµένου ότι, αν ο y ήταν κόκκινος, δεν µπορεί να είναι ο ριζικός κόµβος, ο ριζικός κόµβος παραµένει µαύρος. ΗΥ24 - Παναγιώτα Φατούρου 4 27

28 Κοκκινόµαυρα Δένδρα Διαγραφή q Αν το χρώµα του y είναι µαύρο, η διαγραφή του µπορεί να δηµιουργήσει τα εξής προβλήµατα: Αν ο y ήταν ο ριζικός κόµβος και τεθεί ως νέος ριζικός κάποιος κόκκινος κόµβος, έχει παραβιαστεί η ιδιότητα 2. Αν ο µοναδικός θυγατρικός κόµβος x του y και ο πατρικός κόµβος p του y ήταν και οι δυο κόκκινοι, έχει παραβιαστεί η ιδιότητα 4. Λόγω της διαγραφής του y, όλα τα µονοπάτια που περιείχαν τον y (πριν τη διαγραφή) έχουν ένα µαύρο κόµβο λιγότερο (µετά τη διαγραφή) µετά τη διαγραφή, όλοι οι πρόγονοι του y στο δένδρο παραβιάζουν την ιδιότητα. ΗΥ24 - Παναγιώτα Φατούρου Κοκκινόµαυρα Δένδρα Διαγραφή q Υποθέτουµε ότι η µαύρη ιδιότητα του y µεταφέρεται στο παιδί του (έστω x), το οποίο αν είναι µαύρο γίνεται διπλά µαύρο (που είναι µη επιτρεπτό). Φανταζόµαστε πως κάθε κόµβος έχει ένα και µοναδικό κουπόνι που καθορίζει το χρώµα του (µαύρο ή κόκκινο). Τότε, ένας διπλά-µαύρος κόµβος είναι σαν να έχει δύο κουπόνια µε µαύρο χρώµα. Αυτό είναι µη επιτρεπτό και ο κόµβος πρέπει να απαλλαγεί από το επιπρόσθετο µαύρο κουπόνι. q Προκειµένου να επιτευχθεί αυτό, το επιπρόσθετο µαύρο κουπόνι µεταφέρεται προς τα πάνω (ακολουθώντας το µονοπάτι από τον κόµβο προς τη ρίζα) µέχρι είτε: να φθάσουµε στη ρίζα, ή να βρούµε έναν κόκκινο κόµβο που τον επαναχρωµατίζουµε µαύρο και ο αλγόριθµος τερµατίζει, ή να µπορούν να εκτελεστούν κατάλληλες περιστροφές και επαναχρωµατισµοί κάποιων κόµβων ώστε να επιλυθεί το πρόβληµα. ΗΥ24 - Παναγιώτα Φατούρου 6 28

29 3/28/16 Κοκκινόµαυρα Δένδρα Διαγραφή Θεωρώ ότι το δένδρο υλοποιείται µε κόµβο φρουρό. Έτσι, όλοι οι nill δείκτες δείχνουν στον κόµβο φρουρό. (Αυτό εξυπηρετεί στη µείωση των ελέγχων που απαιτούνται στον κώδικα που θα παρουσιαστεί σε επόµενες διαφάνειες). Σχήµα 13.1: Cormen, Leiserson, ivest & Stein, Εισαγωγή στους Αλγορίθµους, Πανεπιστηµιακές Εκδόσεις Κρήτης, 26 ΗΥ24 - Παναγιώτα Φατούρου 7 Κοκκινόµαυρα Δένδρα- Διαγραφή p q Έστω x το παιδί του κόµβου που διαγράφεται, w ο αδελφικός κόµβος και p ο πατέρας του x. q Αν ο x είναι διπλά µαύρος, ο w δεν µπορεί να είναι ο κόµβος φρουρός. Γιατί; q Υποθέτουµε ότι ο x είναι αριστερό παιδί του πατρικού του κόµβου (η αντίθετη περίπτωση είναι συµµετρική) q Διακρίνουµε περιπτώσεις ως προς το χρώµα του w. Σχήµα 13.7: Cormen, Leiserson, ivest & Stein, Εισαγωγή στους Αλγορίθµους, Πανεπιστηµιακές Εκδόσεις Κρήτης, 26 ΗΥ24 - Παναγιώτα Φατούρου 8 29

30 3/28/16 Κοκκινόµαυρα Δένδρα - Διαγραφή p Βασική Ιδέα Σε όλες τις περιπτώσεις, ο µετασχηµατισµός διατηρεί το πλήθος των µαύρων κόµβων (συµπεριλαµβανοµένου και του extra µαύρου κουπονιού του x) από τον ριζικό κόµβο του εικονιζόµενου υποδένδρου (συµπεριλαµβανοµένου του ριζικού) µέχρι καθένα από τα υποδένδρα α,β,γ,δ,ε και ζ. ΗΥ24 - Παναγιώτα Φατούρου 9 Κοκκινόµαυρα Δένδρα - Διαγραφή 1. Περίπτωση 1: Ο w είναι κόκκινος. Αλλάζουµε το χρώµα του w σε µαύρο και του p σε κόκκινο και εκτελούµε µια αριστερή περιστροφή γύρω από τον πατέρα του x. Έτσι, µεταπίπτουµε στην περίπτωση 2, 3, ή 4. p Περίπτωση 2: Ο w είναι µαύρος κόµβος και τα δύο παιδιά του w είναι µαύρα. Αλλάζουµε το χρώµα του w σε κόκκινο, του x σε µαύρο (από διπλά µαύρο) και µεταφέρουµε το µαύρο που αφαιρέσαµε από τους w, x στον p. Αν ο p ήταν κόκκινος γίνεται µαύρος και ο αλγόριθµος τερµατίζει. Διαφορετικά, ο p γίνεται διπλά µαύρος και ο αλγόριθµος επαναλαµβάνεται µε x = p. ΗΥ24 - Παναγιώτα Φατούρου 6 3

31 3/28/16 Κοκκινόµαυρα Δένδρα - Διαγραφή p 3.Περίπτωση 3: Το w->lc είναι κόκκινο και το w->rc µαύρο. Αλλάζω το χρώµα του w σε κόκκινο και του w->lc σε µαύρο και εκτελώ µια περιστροφή γύρω από το w Μεταπίπτουµε στην περίπτωση 4 4. Περίπτωση 4: Το w->rc είναι κόκκινο. Αλλάζω το χρώµα του w->rc σε µαύρο, του w σε ότι ήταν το χρώµα του p και του p σε µαύρο και εκτελώ µια περιστροφή γύρω από τον p. Ο αλγόριθµος τερµατίζει. ΗΥ24 - Παναγιώτα Φατούρου 61 Κοκκινόµαυρα Δένδρα Διαγραφή - Ψευδοκώδικας edblack-delete(pointer, pointer z) { if (z->c == NULL O z->lc == NULL) y = z; // αν ο z έχει ένα ή κανένα παιδί, διαγράφεται ο ίδιος ο z else y = TreeSuccessor(,z); // διαφορετικά, διαγράφεται ο επόµενος κόµβος στην ενδ/γµένη διάσχιση if (y->lc!= NULL) x = y->lc; // ο x δείχνει στο µοναδικό παιδί του y else x = y->c; x->p = y->p; if (y->p == NULL) (κάνε το x ρίζα του δένδρου); else if (y == y->p->lc) y->p->lc = x; // αν ο y είναι αριστερό παιδί του πατέρα του else y->p->c = x; if (y!= z) { // αν ο προς διαγραφή κόµβος είναι ο επόµενος στην ενδ/γµένη διάσχιση z->key = y->key; // αντιγραφή όλων των πεδίων δεδοµένων (αντιγραφή των υπολοίπων πεδίων δεδοµένων του y στο z); } if (y->color == BLACK) ColorPropertiesDelete(,x); } return y; // αν η διαγραφή αφορούσε κόµβο µε χρώµα µαύρο, εκτέλεση κατάλληλων // ενεργειών για την επαναφορά των ιδιοτήτων χρωµατισµού του δένδρου ΗΥ24 - Παναγιώτα Φατούρου 62 31

32 3/28/16 Κοκκινόµαυρα Δένδρα Διαγραφή - Ψευδοκώδικας ColorPropertiesDelete(pointer, pointer x) { while (x!= AND x->color == BLACK) { if (x == x->p->lc) { // αν ο x είναι αριστερό παιδί w = x->p->c; if (w->color == ED) { // αν αδελφικός του x κόκκινος w->color = BLACK; // Περίπτωση 1 x->p->color = ED; // Περίπτωση 1 Leftotation(, x->p); // Περίπτωση 1 w = x->p->c; // Περίπτωση 1 } if (w->lc->color == BLACK AND w->c->color == BLACK) { // αν και τα δύο παιδιά του w είναι µαύρα w->color = ED; x = x->p; (2) // Περίπτωση 2 // Περίπτωση 2 } else { if (w->c->color == BLACK) { // αν δεξιό παιδί του x µαύρο w->lc->color = BLACK; w->color = ED; ightotation(,w); w = x->p->c; } w->color = x->p->color; x->p->color = BLACK; // Περίπτωση 3 // Περίπτωση 3 // Περίπτωση 3 // Περίπτωση 3 } w->c->color = BLACK;//Περίπτωση 4 Leftotation(, x->p);//περίπτωση 4 x = ; // Περίπτωση 4 } /* else */ } /* if */ else (ίδια µε (2) µε εναλλαγή του LC µε C και το αντίστροφο, καθώς και του Leftotate µε ightotate και το αντίστροφο); } x->color = BLACK; Ποια είναι η χρονική πολυπλοκότητα // Περίπτωση 4 της BDelete()? ΗΥ24 - Παναγιώτα // Περίπτωση 4 Φατούρου 63 Αναφορές Το υλικό της ενότητας αυτής περιέχεται στα ακόλουθα βιβλία: n Harry Lewis and Larry Denenberg, Data Structures and Their Algorithms, Harper Collins Publishers, Inc., New York, 1991 n Cormen, Leiserson, ivest & Stein, Εισαγωγή στους Αλγορίθμους, Πανεπιστηµιακές Εκδόσεις Κρήτης, 26. n Chapter 7: Tree Structures for Dynamic Dictionaries Κεφάλαιο 13: Μελανέρυθρα Δένδρα Ι. Μανωλόπουλος, Δοµές Δεδοµένων, Μια προσέγγιση µε την Pascal, Εκδόσεις Art of Text. Κεφάλαιο : Ισοζυγισµένα Δένδρα ΗΥ24 - Παναγιώτα Φατούρου 64 32

Δομές δεδομένων. Ενότητα 5η: Υλοποίηση Λεξικών με Ισοζυγισμένα Δένδρα Παναγιώτα Φατούρου Τμήμα Επιστήμης Υπολογιστών

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

Διαβάστε περισσότερα

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

ΗΥ240 - Παναγιώτα Φατούρου 2 ΕΝΟΤΗΤΑ ΥΛΟΠΟΙΗΣΗ ΛΕΞΙΚΩΝ ΜΕ ΙΣΟΖΥΓΙΣΜΕΝΑ ΕΝ ΡΑ ΗΥ24 - Παναγιώτα Φατούρου 1 Ισοζυγισµένα ένδρα Χρονική Πολυπλοκότητα αναζήτησης σε δοµές που έχουν ήδη διδάχθει: Στατική Μη-Ταξινοµηµένη Λίστα -> Ο(n), όπου

Διαβάστε περισσότερα

αντικειµένων/στοιχείων (π.χ., σύνολα αριθµών, λέξεων, ζευγών

αντικειµένων/στοιχείων (π.χ., σύνολα αριθµών, λέξεων, ζευγών ΕΝΟΤΗΤΑ ΣΥΝΟΛΑ - ΛΕΞΙΚΑ ΗΥ24 - Παναγιώτα Φατούρου 1 Σύνολα (Sets) Τα µέλη ενός συνόλου προέρχονται από κάποιο χώρο U αντικειµένων/στοιχείων (π.χ., σύνολα αριθµών, λέξεων, ζευγών αποτελούµενα από έναν αριθµό

Διαβάστε περισσότερα

h/2. Άρα, n 2 h/2-1 h 2log(n+1). Πως υλοποιούµε τη LookUp()? Πολυπλοκότητα?

h/2. Άρα, n 2 h/2-1 h 2log(n+1). Πως υλοποιούµε τη LookUp()? Πολυπλοκότητα? Κόκκινα-Μαύρα ένδρα (Red-Black Trees) Ένα κόκκινο-µαύρο δένδρο είναι ένα δυαδικό δένδρο αναζήτησης στο οποίο οι κόµβοι µπορούν να χαρακτηρίζονται από ένα εκ των δύο χρωµάτων: µαύρο-κόκκινο. Το χρώµα της

Διαβάστε περισσότερα

ΕΝΟΤΗΤΑ 5 ΣΥΝΟΛΑ - ΛΕΞΙΚΑ. ΗΥ240 - Παναγιώτα Φατούρου 1

ΕΝΟΤΗΤΑ 5 ΣΥΝΟΛΑ - ΛΕΞΙΚΑ. ΗΥ240 - Παναγιώτα Φατούρου 1 ΕΝΟΤΗΤΑ 5 ΣΥΝΟΛΑ - ΛΕΞΙΚΑ ΗΥ24 - Παναγιώτα Φατούρου 1 Σύνολα (Sets) Τα µέλη ενός συνόλου προέρχονται από κάποιο χώρο U αντικειµένων/στοιχείων (π.χ., σύνολα αριθµών, λέξεων, ζευγών αποτελούµενα από έναν

Διαβάστε περισσότερα

Ενότητα 9 Ξένα Σύνολα που υποστηρίζουν τη λειτουργία της Ένωσης (Union-Find)

Ενότητα 9 Ξένα Σύνολα που υποστηρίζουν τη λειτουργία της Ένωσης (Union-Find) Ενότητα 9 (Union-Find) ΗΥ240 - Παναγιώτα Φατούρου 1 Έστω ότι S 1,, S k είναι ξένα υποσύνολα ενός συνόλου U, δηλαδή ισχύει ότι S i S j =, για κάθε i,j µε i j και S 1 S k = U. Λειτουργίες q MakeSet(X): επιστρέφει

Διαβάστε περισσότερα

ΕΝΟΤΗΤΑ 5 ΥΝΑΜΙΚΑ ΛΕΞΙΚΑ ΙΣΟΖΥΓΙΣΜΕΝΑ ΕΝ ΡΑ

ΕΝΟΤΗΤΑ 5 ΥΝΑΜΙΚΑ ΛΕΞΙΚΑ ΙΣΟΖΥΓΙΣΜΕΝΑ ΕΝ ΡΑ ΕΝΟΤΗΤΑ 5 ΥΝΑΜΙΚΑ ΛΕΞΙΚΑ ΙΣΟΖΥΓΙΣΜΕΝΑ ΕΝ ΡΑ ενδρικές οµές για Υλοποίηση υναµικών Λεξικών υναµικά λεξικά λειτουργίες LookUp( ), Insert( ) και Delete( ) Αναζητούµε δένδρα για την αποτελεσµατική υλοποίηση

Διαβάστε περισσότερα

Ενότητα 7 Ουρές Προτεραιότητας

Ενότητα 7 Ουρές Προτεραιότητας Ενότητα 7 Ουρές Προτεραιότητας ΗΥ240 - Παναγιώτα Φατούρου Ουρές Προτεραιότητας Θεωρούµε ένα χώρο κλειδιών U και έστω ότι µε κάθε κλειδί Κ (τύπου Key) έχει συσχετισθεί κάποια πληροφορία Ι (τύπου Type).

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

ΕΝΟΤΗΤΑ 4 ΣΥΝΟΛΑ - ΛΕΞΙΚΑ

ΕΝΟΤΗΤΑ 4 ΣΥΝΟΛΑ - ΛΕΞΙΚΑ ΕΝΟΤΗΤΑ 4 ΣΥΝΟΛΑ - ΛΕΞΙΚΑ ΗΥ240 - Παναγιώτα Φατούρου 1 Σύνολα (Sets) q Τα µέλη ενός συνόλου προέρχονται από κάποιο χώρο U (universe) αντικειµένων/στοιχείων (π.χ., σύνολα αριθµών, λέξεων, ζευγών σύνολα

Διαβάστε περισσότερα

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

ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ. Δομές δεδομένων. Ενότητα 4η: Σύνολα - Λεξικά Παναγιώτα Φατούρου Τμήμα Επιστήμης Υπολογιστών ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ Δομές δεδομένων Ενότητα 4η: Σύνολα - Λεξικά Παναγιώτα Φατούρου Τμήμα Επιστήμης Υπολογιστών ΕΝΟΤΗΤΑ 4 ΣΥΝΟΛΑ - ΛΕΞΙΚΑ ΗΥ240 - Παναγιώτα Φατούρου 2 Σύνολα (Sets) Τα

Διαβάστε περισσότερα

Ενότητα 7 Ουρές Προτεραιότητας

Ενότητα 7 Ουρές Προτεραιότητας Ενότητα Ουρές Προτεραιότητας ΗΥ4 - Παναγιώτα Φατούρου Ουρές Προτεραιότητας Θεωρούµε ένα χώρο κλειδιών U και έστω ότι µε κάθε κλειδί Κ (τύπου Key) έχει συσχετισθεί κάποια πληροφορία Ι (τύπου Type). Έστω

Διαβάστε περισσότερα

Ενότητα 9 Ξένα Σύνολα που υποστηρίζουν τη λειτουργία της Ένωσης (Union-Find)

Ενότητα 9 Ξένα Σύνολα που υποστηρίζουν τη λειτουργία της Ένωσης (Union-Find) Ενότητα 9 Ξένα Σύνολα που υποστηρίζουν τη (Union-Find) ΗΥ240 - Παναγιώτα Φατούρου 1 Ξένα Σύνολα που υποστηρίζουν τη λειτουργία της Ένωσης Έστω ότι S 1,, S k είναι ξένα υποσύνολα ενός συνόλου U, δηλαδή

Διαβάστε περισσότερα

Ισορροπημένα Δένδρα. για κάθε λειτουργία; Ισορροπημένο δένδρο : Διατηρεί ύψος κάθε εισαγωγή ή διαγραφή

Ισορροπημένα Δένδρα. για κάθε λειτουργία; Ισορροπημένο δένδρο : Διατηρεί ύψος κάθε εισαγωγή ή διαγραφή Ισορροπημένα Δένδρα Μπορούμε να επιτύχουμε για κάθε λειτουργία; χρόνο εκτέλεσης Ισορροπημένο δένδρο : Διατηρεί ύψος κάθε εισαγωγή ή διαγραφή μετά από Περιστροφές x αριστερή περιστροφή από το x y α β y

Διαβάστε περισσότερα

Δομές δεδομένων. Ενότητα 8: Ξένα Σύνολα που υποστηρίζουν τη λειτουργία της Ένωσης (Union-Find) Παναγιώτα Φατούρου Τμήμα Επιστήμης Υπολογιστών

Δομές δεδομένων. Ενότητα 8: Ξένα Σύνολα που υποστηρίζουν τη λειτουργία της Ένωσης (Union-Find) Παναγιώτα Φατούρου Τμήμα Επιστήμης Υπολογιστών ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ Δομές δεδομένων Ενότητα 8: Ξένα Σύνολα που υποστηρίζουν τη λειτουργία της Ένωσης (Union-Find) Παναγιώτα Φατούρου Τμήμα Επιστήμης Υπολογιστών Ενότητα 8 Ξένα Σύνολα

Διαβάστε περισσότερα

Ισορροπημένα Δένδρα. για κάθε λειτουργία; Ισορροπημένο δένδρο : Διατηρεί ύψος κάθε εισαγωγή ή διαγραφή

Ισορροπημένα Δένδρα. για κάθε λειτουργία; Ισορροπημένο δένδρο : Διατηρεί ύψος κάθε εισαγωγή ή διαγραφή Ισορροπημένα Δένδρα Μπορούμε να επιτύχουμε για κάθε λειτουργία; χρόνο εκτέλεσης Ισορροπημένο δένδρο : Διατηρεί ύψος κάθε εισαγωγή ή διαγραφή μετά από Περιστροφές x αριστερή περιστροφή από το x y α β y

Διαβάστε περισσότερα

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

Insert(K,I,S) Delete(K,S) ΕΝΟΤΗΤΑ 5 ΣΥΝΟΛΑ & ΛΕΞΙΚΑ Φατούρου Παναγιώτα 1 Σύνολα (Sets) Τα µέλη ενός συνόλου προέρχονται από κάποιο χώρο αντικειµένων/στοιχείων (π.χ., σύνολα αριθµών, λέξεων, ζευγών αποτελούµενα από έναν αριθµό και

Διαβάστε περισσότερα

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

Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων ομές εδομένων Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων 6. Δυαδικά Δέντρα 2 ομές εδομένων 4 5 Χρήστος ουλκερίδης Τμήμα Ψηφιακών Συστημάτων 18/11/2016 Εισαγωγή Τα

Διαβάστε περισσότερα

Εκτενείς Δομές Δεδομένων

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

Διαβάστε περισσότερα

Εκτενείς Δομές Δεδομένων

Εκτενείς Δομές Δεδομένων Εκτενείς Δομές Δεδομένων Εισαγωγή Δομές που βασίζονται σε συγκρίσεις : Ισοζυγισμένα δέντρα εύρεσης ( δέντρα τα φύλλα των οποίων απέχουν της ίδιας τάξεως μεγέθους, απόσταση απο τη ρίζα) Υψοζυγισμένα δέντρα

Διαβάστε περισσότερα

ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ

ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ Δομές δεδομένων Άσκηση αυτοαξιολόγησης 3-4 Παναγιώτα Φατούρου Τμήμα Επιστήμης Υπολογιστών Ενότητες 3 & 4: ένδρα, Σύνολα & Λεξικά Ασκήσεις και Λύσεις Άσκηση 1 Γράψτε

Διαβάστε περισσότερα

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

Ενότητες 3 & 4: Δένδρα, Σύνολα & Λεξικά Ασκήσεις και Λύσεις Ενότητες 3 & 4: Δένδρα, Σύνολα & Λεξικά Ασκήσεις και Λύσεις Άσκηση 1 Γράψτε μία αναδρομική συνάρτηση που θα παίρνει ως παράμετρο ένα δείκτη στη ρίζα ενός δυαδικού δένδρου και θα επιστρέφει το βαθμό του

Διαβάστε περισσότερα

Red- black δέντρα Εκτενείς Δομές Δεδομένων (Κεφ. 5)

Red- black δέντρα Εκτενείς Δομές Δεδομένων (Κεφ. 5) ΤΜΗΜΑ ΜΗΧΑΝΙΚΩΝ Η/Υ ΚΑΙ ΠΛΗΡΟΦΟΡΙΚΗΣ Red- black δέντρα Εκτενείς Δομές Δεδομένων (Κεφ. ) Δομές Δεδομένων Μπαλτάς Αλέξανδρος 4 Μαρτίου 0 ampaltas@ceid.upatras.gr Περιεχόμενα. Εισαγωγή. Ορισμός red- black

Διαβάστε περισσότερα

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

Δομές Δεδομένων. Ενότητα 13: B-Δέντρα/AVL-Δέντρα. Καθηγήτρια Μαρία Σατρατζέμη. Τμήμα Εφαρμοσμένης Πληροφορικής. Δομές Δεδομένων Ενότητα 13: B-Δέντρα/AVL-Δέντρα Καθηγήτρια Μαρία Σατρατζέμη Άδειες Χρήσης Το παρόν εκπαιδευτικό υλικό υπόκειται σε άδειες χρήσης Creative Commons. Για εκπαιδευτικό υλικό, όπως εικόνες, που υπόκειται σε

Διαβάστε περισσότερα

Red-black δέντρα (Κεφ. 5)

Red-black δέντρα (Κεφ. 5) Red-black δέντρα (Κεφ. ) Δομές Δεδομένων Παπαγιαννόπουλος Δημήτριος 30 Μαρτίου 07 30 Μαρτίου 07 papagianno@ceid.upatras.gr . Εισαγωγή Περιεχόμενα. Ορισμός red-black δέντρων 3. Αναζήτηση σε red-black δέντρα

Διαβάστε περισσότερα

ΕΝΟΤΗΤΑ 4 ΣΥΝΟΛΑ - ΛΕΞΙΚΑ

ΕΝΟΤΗΤΑ 4 ΣΥΝΟΛΑ - ΛΕΞΙΚΑ ΕΝΟΤΗΤΑ 4 ΣΥΝΟΛΑ - ΛΕΞΙΚΑ ΗΥ240 - Παναγιώτα Φατούρου Σύνολα (Sets) Τα µέλη ενός συνόλου προέρχονται από κάποιο χώρο U αντικειµένων/στοιχείων (π.χ., σύνολα αριθµών, λέξεων, ζευγών αποτελούµενων από έναν

Διαβάστε περισσότερα

9. Κόκκινα-Μαύρα Δέντρα

9. Κόκκινα-Μαύρα Δέντρα Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων 9. Κόκκινα-Μαύρα Δέντρα 2 ομές εδομένων 4 5 Χρήστος ουλκερίδης Τμήμα Ψηφιακών Συστημάτων 9/12/2016 Δέντρα,

Διαβάστε περισσότερα

Κεφάλαιο 8 Ισορροπημένα Δένδρα Αναζήτησης

Κεφάλαιο 8 Ισορροπημένα Δένδρα Αναζήτησης Κεφάλαιο 8 Ισορροπημένα Δένδρα Αναζήτησης Περιεχόμενα 8.1 Κατηγορίες ισορροπημένων δένδρων αναζήτησης... 155 8.1.1 Περιστροφές... 156 8.2 Δένδρα AVL... 157 8.2.1 Αποκατάσταση συνθήκης ισορροπίας... 158

Διαβάστε περισσότερα

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

ΗΥ240 - Παναγιώτα Φατούρου 1 ΕΝΟΤΗΤΑ 3 ΔΕΝΔΡΑ ΗΥ240 - Παναγιώτα Φατούρου 1 Δένδρα Ένα δένδρο Τ αποτελείται από ένα σύνολο από κόµβους µεταξύ των οποίων ορίζεται µια σχέση γονέα-παιδιού µε τις εξής ιδιότητες: q Αν το Τ δεν είναι το

Διαβάστε περισσότερα

Ισοζυγισμένα υαδικά έντρα Αναζήτησης

Ισοζυγισμένα υαδικά έντρα Αναζήτησης Ισοζυγισμένα υαδικά έντρα Αναζήτησης ομές εδομένων 3ο εξάμηνο ιδάσκων: Χρήστος ουλκερίδης ιαφάνειες προσαρμοσμένες από το υλικό της Μαρίας Χαλκίδη Ισοζυγισμένα υαδικά έντρα Αναζήτησης Ισοζυγισμένα Α είναι

Διαβάστε περισσότερα

Δένδρα Αναζήτησης Πολλαπλής Διακλάδωσης

Δένδρα Αναζήτησης Πολλαπλής Διακλάδωσης Δένδρα Αναζήτησης Πολλαπλής Διακλάδωσης Δένδρα στα οποία κάθε κόμβος μπορεί να αποθηκεύει ένα ή περισσότερα κλειδιά. Κόμβος με d διακλαδώσεις : k 1 k 2 k 3 k 4 d-1 διατεταγμένα κλειδιά d διατεταγμένα παιδιά

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

ένδρα (tail, head) Γονέας Παιδί (ancestor, descendant) Φύλλο Εσωτερικός Κόµβος (leaf, non-leaf) που αποτελεί το γονέα του v. ΕΝΟΤΗΤΑ 4 ΕΝ ΡΑ ΗΥ240 - Παναγιώτα Φατούρου 1 ένδρα Κόµβοι (nodes) Ακµές (edges) Ουρά και κεφαλή ακµής (tail, head) Γονέας Παιδί Αδελφικός κόµβος (parent, child, sibling) Μονοπάτι (path) Πρόγονος απόγονος

Διαβάστε περισσότερα

Εισαγωγή ενός νέου στοιχείου. Επιλογή i-οστoύ στοιχείου : Εύρεση στοιχείου με το i-οστό μικρότερο κλειδί

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

Διαβάστε περισσότερα

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

ΕΝΟΤΗΤΑ 7 ΟΥΡΕΣ ΠΡΟΤΕΡΑΙΟΤΗΤΑΣ ΣΩΡΟΙ ΕΝΟΤΗΤΑ 7 ΟΥΡΕΣ ΠΡΟΤΕΡΑΙΟΤΗΤΑΣ ΣΩΡΟΙ Ουρές Προτεραιότητας (Priority Queues) Θεωρούµε ότι τα προς αποθήκευση στοιχεία έχουν κάποια διάταξη (καθένα έχει µια προτεραιότητα). Τα προς αποθήκευση στοιχεία είναι

Διαβάστε περισσότερα

Στοιχεία Θεωρίας Γραφηµάτων (4) - έντρα

Στοιχεία Θεωρίας Γραφηµάτων (4) - έντρα Στοιχεία Θεωρίας Γραφηµάτων (4) - έντρα Ορέστης Τελέλης tllis@unipi.r Τµήµα Ψηφιακών Συστηµάτων, Πανεπιστήµιο Πειραιώς Ο. Τελέλης Πανεπιστήµιο Πειραιώς έντρα 1 / 27 έντρα έντρο είναι απλό συνδεδεµένο µη

Διαβάστε περισσότερα

ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ

ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΕΠΛ 23: οµές εδοµένων και Αλγόριθµοι Ενδιάµεση Εξέταση Ηµεροµηνία : ευτέρα, 3 Νοεµβρίου 2008 ιάρκεια : 2.00-4.00 ιδάσκουσα : Άννα Φιλίππου Ονοµατεπώνυµο: ΣΚΕΛΕΤΟΙ

Διαβάστε περισσότερα

Ενότητα 1: Εισαγωγή Ασκήσεις και Λύσεις

Ενότητα 1: Εισαγωγή Ασκήσεις και Λύσεις Ενότητα 1: Εισαγωγή Ασκήσεις και Λύσεις Άσκηση 1 Αποδείξτε τη µεταβατική και τη συµµετρική ιδιότητα του Θ. Λύση Μεταβατική Ιδιότητα (ορισµός): Αν f(n) = Θ(g(n)) και g(n) = Θ(h(n)) τότε f(n)=θ(h(n)). Για

Διαβάστε περισσότερα

Κεφάλαιο 14 Προηγμένες Ουρές Προτεραιότητας

Κεφάλαιο 14 Προηγμένες Ουρές Προτεραιότητας Κεφάλαιο 14 Προηγμένες Ουρές Προτεραιότητας Περιεχόμενα 14.1 Διωνυμικά Δένδρα... 255 14.2 Διωνυμικές Ουρές... 258 14.1.1 Εισαγωγή στοιχείου σε διωνυμική ουρά... 258 14.1.2 Διαγραφή μεγίστου από διωνυμική

Διαβάστε περισσότερα

Διακριτά Μαθηματικά ΙΙ Χρήστος Νομικός Τμήμα Μηχανικών Η/Υ και Πληροφορικής Πανεπιστήμιο Ιωαννίνων 2018 Χρήστος Νομικός ( Τμήμα Μηχανικών Η/Υ Διακριτά

Διακριτά Μαθηματικά ΙΙ Χρήστος Νομικός Τμήμα Μηχανικών Η/Υ και Πληροφορικής Πανεπιστήμιο Ιωαννίνων 2018 Χρήστος Νομικός ( Τμήμα Μηχανικών Η/Υ Διακριτά Διακριτά Μαθηματικά ΙΙ Χρήστος Νομικός Τμήμα Μηχανικών Η/Υ και Πληροφορικής Πανεπιστήμιο Ιωαννίνων 2018 Χρήστος Νομικός ( Τμήμα Μηχανικών Η/Υ Διακριτά και Πληροφορικής Μαθηματικά Πανεπιστήμιο ΙΙ Ιωαννίνων

Διαβάστε περισσότερα

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

Διάλεξη 13: Δέντρα ΙΙΙ Ισοζυγισμένα Δέντρα, AVL Δέντρα. Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 13: Δέντρα ΙΙΙ Ισοζυγισμένα Δέντρα, AVL Δέντρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Ισοζυγισμένα Δέντρα Υλοποίηση AVL δέντρων Εισαγωγή Κόμβων και Περιστροφές σε AVL δέντρα

Διαβάστε περισσότερα

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

Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 12: Δέντρα ΙΙ -Δυαδικά Δέντρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Δυαδικά Δένδρα - Δυαδικά Δένδρα Αναζήτησης(ΔΔΑ) - Εύρεση Τυχαίου, Μέγιστου, Μικρότερου στοιχείου - Εισαγωγή

Διαβάστε περισσότερα

Πρόβληµα (ADT) Λεξικού. Αλγόριθµοι & Πολυπλοκότητα (Χειµώνας 2011) Λεξικό, Union - Find 2

Πρόβληµα (ADT) Λεξικού. Αλγόριθµοι & Πολυπλοκότητα (Χειµώνας 2011) Λεξικό, Union - Find 2 Πρόβληµα (ADT) Λεξικού Αλγόριθµοι & Πολυπλοκότητα (Χειµώνας 2011) Λεξικό, Union - Find 2 Πρόβληµα (ADT) Λεξικού Δυναµικά µεταβαλλόµενη συλλογή αντικειµένων που αναγνωρίζονται µε κλειδί (π.χ. κατάλογοι,

Διαβάστε περισσότερα

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

Αλγόριθμοι και Δομές Δεδομένων (IΙ) (γράφοι και δένδρα) Ιόνιο Πανεπιστήμιο Τμήμα Πληροφορικής Εισαγωγή στην Επιστήμη των Υπολογιστών 2016-17 Αλγόριθμοι και Δομές Δεδομένων (IΙ) (γράφοι και δένδρα) http://mixstef.github.io/courses/csintro/ Μ.Στεφανιδάκης Αφηρημένες

Διαβάστε περισσότερα

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

Δομές Δεδομένων και Αλγόριθμοι Δομές Δεδομένων και Αλγόριθμοι Χρήστος Γκόγκος ΤΕΙ Ηπείρου Χειμερινό Εξάμηνο 2014-2015 Παρουσίαση 16 Δένδρα (Trees) 1 / 42 Δένδρα (Trees) Ένα δένδρο είναι ένα συνδεδεμένο γράφημα χωρίς κύκλους Για κάθε

Διαβάστε περισσότερα

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

ΗΥ240: Δομές Δεδομένων Εαρινό Εξάμηνο Ακαδημαϊκό Έτος 2018 Διδάσκουσα: Παναγιώτα Φατούρου Προγραμματιστική Εργασία - 2o Μέρος ΗΥ240: Δομές Δεδομένων Εαρινό Εξάμηνο Ακαδημαϊκό Έτος 2018 Διδάσκουσα: Παναγιώτα Φατούρου Προγραμματιστική Εργασία - 2o Μέρος Ημερομηνία Παράδοσης: Δευτέρα, 14 Μαΐου 2018, ώρα 23:59 Τρόπος Παράδοσης: Χρησιμοποιώντας

Διαβάστε περισσότερα

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

Διάλεξη 22: Δυαδικά Δέντρα. Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 22: Δυαδικά Δέντρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Δυαδικά Δένδρα - Δυαδικά Δένδρα Αναζήτησης - Πράξεις Εισαγωγής, Εύρεσης Στοιχείου, Διαγραφής Μικρότερου Στοιχείου

Διαβάστε περισσότερα

Κεφάλαιο 2. Η δοµή δεδοµένων Σωρός και η Ταξινόµηση Σωρού (The Heap data structure and Heapsort) Έκδοση 1.1, 12/05/2010

Κεφάλαιο 2. Η δοµή δεδοµένων Σωρός και η Ταξινόµηση Σωρού (The Heap data structure and Heapsort) Έκδοση 1.1, 12/05/2010 Κεφάλαιο 2 Η δοµή δεδοµένων Σωρός και η Ταξινόµηση Σωρού (The Heap data structure and Heapsort) Έκδοση., 2/05/200 Χρησιµοποιήθηκε υλικό από τις αγγλικές διαφάνειες του Kevin Wayne. Σωρός και Ταξινόµηση

Διαβάστε περισσότερα

Το Πρόβληµα Οµοφωνίας Σύγχρονα Συστήµατα Μεταβίβασης Μηνύµατος Μοντέλο Κατάρρευσης (crash model) Οι διεργασίες µπορούν να σταµατούν να εκτελούνται σε

Το Πρόβληµα Οµοφωνίας Σύγχρονα Συστήµατα Μεταβίβασης Μηνύµατος Μοντέλο Κατάρρευσης (crash model) Οι διεργασίες µπορούν να σταµατούν να εκτελούνται σε Οµοφωνία σε σύστηµα µε αϖοτυχίες διεργασιών Παναγιώτα Φατούρου Κατανεµηµένα Συστήµατα 1 Το Πρόβληµα Οµοφωνίας Σύγχρονα Συστήµατα Μεταβίβασης Μηνύµατος Μοντέλο Κατάρρευσης (crash model) Οι διεργασίες µπορούν

Διαβάστε περισσότερα

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

Διάλεξη 17: Δυαδικά Δέντρα. Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ Διάλεξη 7: Δυαδικά Δέντρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Δυαδικά Δένδρα Δυαδικά Δένδρα Αναζήτησης Πράξεις Εισαγωγής, Εύρεσης Στοιχείου, Διαγραφής Μικρότερου Στοιχείου Διδάσκων:

Διαβάστε περισσότερα

ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ

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

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

Διάλεξη 13: Δέντρα ΙΙΙ Ισοζυγισμένα Δέντρα, AVL Δέντρα Διάλεξη 13: Δέντρα ΙΙΙ Ισοζυγισμένα Δέντρα, AVL Δέντρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Ισοζυγισμένα Δέντρα Υλοποίηση AVL δέντρων Εισαγωγή Κόμβων και Περιστροφές σε AVL δέντρα

Διαβάστε περισσότερα

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

οµές εδοµένων 3 ο Εξάµηνο ΕΝΟΤΗΤΑ 4 ΕΝ ΡΑ ΕΝΟΤΗΤΑ 4 ΕΝ ΡΑ 1 ένδρα εσωτερικός κόµβος u το δένδρο έχει ύψος 4 u έχει ύψος 3 w έχει βάθος 2 κόµβος ένδρο: γράφηµα χωρίς κύκλους o Ρίζα (root) o Κόµβος (node) o Ακµή (edge) o Γονέας (parent) Παιδί (child)

Διαβάστε περισσότερα

Δομές Δεδομένων (Εργ.) Ακ. Έτος Διδάσκων: Ευάγγελος Σπύρου. Εργαστήριο 10 Δυαδικά Δένδρα Αναζήτησης

Δομές Δεδομένων (Εργ.) Ακ. Έτος Διδάσκων: Ευάγγελος Σπύρου. Εργαστήριο 10 Δυαδικά Δένδρα Αναζήτησης ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΠΑΝΕΠΙΣΤΗΜΙΟ ΘΕΣΣΑΛΙΑΣ Δομές Δεδομένων (Εργ.) Ακ. Έτος 2017-18 Διδάσκων: Ευάγγελος Σπύρου Εργαστήριο 10 Δυαδικά Δένδρα Αναζήτησης 1. Στόχος του εργαστηρίου Στόχος του δέκατου εργαστηρίου

Διαβάστε περισσότερα

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

ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ. Δομές δεδομένων. Ενότητα 10η: Γράφοι Παναγιώτα Φατούρου Τμήμα Επιστήμης Υπολογιστών ΕΛΛΗΝΙΚΗ ΔΗΜΟΚΡΑΤΙΑ ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΡΗΤΗΣ Δομές δεδομένων Ενότητα 10η: Γράφοι Παναγιώτα Φατούρου Τμήμα Επιστήμης Υπολογιστών Ενότητα 10 Γράφοι ΗΥ240 - Παναγιώτα Φατούρου 2 Γράφοι (ή Γραφήματα) Ένας γράφος

Διαβάστε περισσότερα

ΕΝΟΤΗΤΑ 6 ΛΙΣΤΕΣ ΠΑΡΑΛΕΙΨΗΣ (SKIP LISTS)

ΕΝΟΤΗΤΑ 6 ΛΙΣΤΕΣ ΠΑΡΑΛΕΙΨΗΣ (SKIP LISTS) ΕΝΟΤΗΤΑ 6 ΛΙΣΤΕΣ ΠΑΡΑΛΕΙΨΗΣ (SKIP LISTS) Ταχεία Αναζήτηση Σε πίνακα: δυαδική αναζήτηση (binary search) σε ταξινοµηµένο πίνακα O(log n) Σε δένδρο: αναζήτηση σε ισοζυγισµένο δένδρο O(log n) Σε λίστα: Μπορούµε

Διαβάστε περισσότερα

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

Διάλεξη 12: Δέντρα ΙΙ Δυαδικά Δέντρα Διάλεξη 12: Δέντρα ΙΙ Δυαδικά Δέντρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Δυαδικά Δένδρα Δυαδικά Δένδρα Αναζήτησης (ΔΔΑ) Εύρεση Τυχαίου, Μέγιστου, Μικρότερου στοιχείου Εισαγωγή στοιχείου

Διαβάστε περισσότερα

Το Πρόβληµα Οµοφωνίας Σύγχρονα Συστήµατα Μεταβίβασης Μηνύµατος Μοντέλο Κατάρρευσης (crash model) Οι διεργασίες µπορούν να σταµατούν να εκτελούνται σε

Το Πρόβληµα Οµοφωνίας Σύγχρονα Συστήµατα Μεταβίβασης Μηνύµατος Μοντέλο Κατάρρευσης (crash model) Οι διεργασίες µπορούν να σταµατούν να εκτελούνται σε Οµοφωνία σε σύγχρονο σύστηµα µε αϖοτυχίες κατάρρευσης διεργασιών Παναγιώτα Φατούρου Κατανεµηµένος Υπολογισµός 1 Το Πρόβληµα Οµοφωνίας Σύγχρονα Συστήµατα Μεταβίβασης Μηνύµατος Μοντέλο Κατάρρευσης (crash

Διαβάστε περισσότερα

Διαχρονικές δομές δεδομένων

Διαχρονικές δομές δεδομένων Διαχρονικές δομές δεδομένων Μια τυπική δομή δεδομένων μεταβάλλεται με πράξεις εισαγωγής ή διαγραφής Π.χ. κοκκινόμαυρο δένδρο εισαγωγή 0 18 0 5 39 73 1 46 6 80 Αποκατάσταση ισορροπίας 5 39 73 0 46 6 80

Διαβάστε περισσότερα

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

Δυαδικά Δένδρα Αναζήτησης, Δένδρα AVL Δυαδικά Δένδρα Αναζήτησης, Δένδρα AVL Υλικό από τις σηµειώσεις Ν. Παπασπύρου, 2006 Δέντρα δυαδικής αναζήτησης Δενδρικές δοµές δεδοµένων στις οποίες Όλα τα στοιχεία στο αριστερό υποδέντρο της ρίζας είναι

Διαβάστε περισσότερα

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

ΠΑΡΑΡΤΗΜΑ: QUIZ ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ ΠΑΡΑΡΤΗΜΑ: QUIZ ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ (Οι ερωτήσεις µε κίτρινη υπογράµµιση είναι εκτός ύλης για φέτος) ΕΙΣΑΓΩΓΗ Q1. Οι Πρωταρχικοί τύποι (primitive types) στη Java 1. Είναι όλοι οι ακέραιοι και όλοι οι πραγµατικοί

Διαβάστε περισσότερα

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

ΕΠΛ 231 οµές εδοµένων και Αλγόριθµοι Άννα Φιλίππου, 2006 9-1 Σωροί Στην ενότητα αυτή θα µελετηθούν τα εξής επιµέρους θέµατα: Ουρές Προτεραιότητας Σωροί υλοποίηση και πράξεις Ο αλγόριθµος ταξινόµησης HeapSort Παραλλαγές Σωρών ΕΠΛ 231 οµές εδοµένων και Αλγόριθµοι

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

Δοµές Δεδοµένων. 18η Διάλεξη Ισορροπηµένα δέντρα. Ε. Μαρκάκης

Δοµές Δεδοµένων. 18η Διάλεξη Ισορροπηµένα δέντρα. Ε. Μαρκάκης Δοµές Δεδοµένων 18η Διάλεξη Ισορροπηµένα δέντρα Ε. Μαρκάκης Περίληψη Επανάληψη των Τυχαιοποιηµένων ΔΔΑ, Στρεβλών ΔΔΑ, Δέντρων 2-3-4 Δέντρα κόκκινου-µαύρου Λίστες Παράλειψης Χαρακτηριστικά επιδόσεων - συµπεράσµατα

Διαβάστε περισσότερα

ΟΙΚΟΝΟΜΙΚΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΑΘΗΝΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ. Δοµές Δεδοµένων

ΟΙΚΟΝΟΜΙΚΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΑΘΗΝΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ. Δοµές Δεδοµένων ΟΝΟΜΑΤΕΠΩΝΥΜΟ: ΟΙΚΟΝΟΜΙΚΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΑΘΗΝΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ AM: Δοµές Δεδοµένων Εξεταστική Ιανουαρίου 2014 Διδάσκων : Ευάγγελος Μαρκάκης 20.01.2014 ΥΠΟΓΡΑΦΗ ΕΠΟΠΤΗ: Διάρκεια εξέτασης : 2 ώρες και

Διαβάστε περισσότερα

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

ΕΝΟΤΗΤΑ 4 ΕΝ ΡΑ. ΗΥ240 - Παναγιώτα Φατούρου 1 ΕΝΟΤΗΤΑ 4 ΕΝ ΡΑ ΗΥ240 - Παναγιώτα Φατούρου 1 ένδρα Κόµβοι (nodes) Ακµές (edges) Ουρά και κεφαλή ακµής (tail, head) Γονέας Παιδί Αδελφικός κόµβος (parent, child, sibling) Μονοπάτι (path) Πρόγονος απόγονος

Διαβάστε περισσότερα

Αλγόριθµοι και Πολυπλοκότητα

Αλγόριθµοι και Πολυπλοκότητα Αλγόριθµοι και Πολυπλοκότητα Ν. Μ. Μισυρλής Τµήµα Πληροφορικής και Τηλεπικοινωνιών, Πανεπιστήµιο Αθηνών Καθηγητής: Ν. Μ. Μισυρλής () Αλγόριθµοι και Πολυπλοκότητα Φεβρουαρίου 0 / ένδρα Ενα δένδρο είναι

Διαβάστε περισσότερα

Ισορροπημένα Δένδρα. για κάθε λειτουργία; Ισορροπημένο δένδρο : Διατηρεί ύψος κάθε εισαγωγή ή διαγραφή

Ισορροπημένα Δένδρα. για κάθε λειτουργία; Ισορροπημένο δένδρο : Διατηρεί ύψος κάθε εισαγωγή ή διαγραφή Ισορροπημένα Δένδρα Μπορούμε να επιτύχουμε για κάθε λειτουργία; χρόνο εκτέλεσης Ισορροπημένο δένδρο : Διατηρεί ύψος κάθε εισαγωγή ή διαγραφή μετά από Περιστροφές x αριστερή περιστροφή από το x y α β y

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

Κατ οίκον Εργασία 3 Σκελετοί Λύσεων Άσκηση 1 Χρησιµοποιούµε τη δοµή Κατ οίκον Εργασία 3 Σκελετοί Λύσεων typedef struct Node int data; struct node *lchild; struct node *rbro; node; και υποθέτουµε πως ένα τυχαίο δένδρο είναι υλοποιηµένο ως

Διαβάστε περισσότερα

Ισορροπημένα Δένδρα. για κάθε λειτουργία; Ισορροπημένο δένδρο : Διατηρεί ύψος κάθε εισαγωγή ή διαγραφή

Ισορροπημένα Δένδρα. για κάθε λειτουργία; Ισορροπημένο δένδρο : Διατηρεί ύψος κάθε εισαγωγή ή διαγραφή Ισορροπημένα Δένδρα Μπορούμε να επιτύχουμε για κάθε λειτουργία; χρόνο εκτέλεσης Ισορροπημένο δένδρο : Διατηρεί ύψος κάθε εισαγωγή ή διαγραφή μετά από Περιστροφές x αριστερή περιστροφή από το x y α β y

Διαβάστε περισσότερα

Βασικές Προτάσεις. έντρα. υαδικά έντρα Αναζήτησης ( Α) Ισοζυγισµένα έντρα και Υψος. Κάθε δέντρο µε n κόµβους έχει n 1 ακµές.

Βασικές Προτάσεις. έντρα. υαδικά έντρα Αναζήτησης ( Α) Ισοζυγισµένα έντρα και Υψος. Κάθε δέντρο µε n κόµβους έχει n 1 ακµές. Βασικές Προτάσεις έντρα Ορέστης Τελέλης Κάθε δέντρο µε n κόµβους έχει n ακµές. ικαιολόγηση: Με επαγωγή στο πλήθος των κόµβων, n. έντρο µε k εσωτερικούς κόµβους και l ϕύλλα έχει n = k + l κόµβους. tllis@unipi.r

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

ΟΙΚΟΝΟΜΙΚΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΑΘΗΝΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ. Δοµές Δεδοµένων

ΟΙΚΟΝΟΜΙΚΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΑΘΗΝΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ. Δοµές Δεδοµένων ΟΝΟΜΑΤΕΠΩΝΥΜΟ: ΟΙΚΟΝΟΜΙΚΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΑΘΗΝΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ AM: Δοµές Δεδοµένων Πτυχιακή Εξεταστική Ιούλιος 2014 Διδάσκων : Ευάγγελος Μαρκάκης 09.07.2014 ΥΠΟΓΡΑΦΗ ΕΠΟΠΤΗ: Διάρκεια εξέτασης : 2 ώρες

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

Οργάνωση αρχείων: πως είναι τοποθετηµένες οι εγγραφές ενός αρχείου όταν αποθηκεύονται στο δίσκο

Οργάνωση αρχείων: πως είναι τοποθετηµένες οι εγγραφές ενός αρχείου όταν αποθηκεύονται στο δίσκο Κατακερµατισµός 1 Οργάνωση Αρχείων (σύνοψη) Οργάνωση αρχείων: πως είναι τοποθετηµένες οι εγγραφές ενός αρχείου όταν αποθηκεύονται στο δίσκο 1. Αρχεία Σωρού 2. Ταξινοµηµένα Αρχεία Φυσική διάταξη των εγγραφών

Διαβάστε περισσότερα

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

Διδάσκων: Κωνσταντίνος Κώστα Διάλεξη Ε4: Επανάληψη Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Εισαγωγή σε δενδρικές δομές δεδομένων, Δυαδικά Δένδρα Αναζήτησης Ισοζυγισμένα Δένδρα & 2-3 Δένδρα Διδάσκων: Κωνσταντίνος

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 23: Ισοζυγισμένα Δέντρα, AVL Δέντρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Ισοζυγισμένα Δέντρα - Υλοποίηση AVL-δέντρων - Εισαγωγή Κόμβων και Περιστροφές σε AVL δέντρα Διδάσκων:

Διαβάστε περισσότερα

Οι βασικές πράξεις που ορίζουν τον ΑΤ δυαδικό δέντρο αναζήτησης είναι οι ακόλουθες:

Οι βασικές πράξεις που ορίζουν τον ΑΤ δυαδικό δέντρο αναζήτησης είναι οι ακόλουθες: υαδικά έντρα Αναζήτησης (Binary Search Trees) Ορισµός : Ένα δυαδικό δέντρο αναζήτησης t είναι ένα δυαδικό δέντρο, το οποίο είτε είναι κενό είτε: (i) όλα τα περιεχόµενα στο αριστερό υποδέντρο του t είναι

Διαβάστε περισσότερα

Διάλεξη 17: O Αλγόριθμος Ταξινόμησης HeapSort

Διάλεξη 17: O Αλγόριθμος Ταξινόμησης HeapSort Διάλεξη 17: O Αλγόριθμος Ταξινόμησης HeapSort Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Η διαδικασία PercolateDown, Δημιουργία Σωρού O Αλγόριθμος Ταξινόμησης HeapSort Υλοποίηση, Παραδείγματα

Διαβάστε περισσότερα

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

ΣΧΟΛΗ ΔΙΟΙΚΗΣΗΣ ΚΑΙ ΟΙΚΟΝΟΜΙΑΣ ΤΜΗΜΑ ΔΙΟΙΚΗΣΗΣ ΕΠΙΧΕΙΡΗΣΕΩΝ (ΠΑΤΡΑ) ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ ΣΧΟΛΗ ΔΙΟΙΚΗΣΗΣ ΚΑΙ ΟΙΚΟΝΟΜΙΑΣ ΤΜΗΜΑ ΔΙΟΙΚΗΣΗΣ ΕΠΙΧΕΙΡΗΣΕΩΝ (ΠΑΤΡΑ) ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ Γιάννης Κουτσονίκος Επίκουρος Καθηγητής Οργάνωση Δεδομένων Δομή Δεδομένων: τεχνική οργάνωσης των δεδομένων με σκοπό την

Διαβάστε περισσότερα

Όρια Αλγόριθμων Ταξινόμησης. Εισαγωγή στην Ανάλυση Αλγορίθμων Μάγια Σατρατζέμη

Όρια Αλγόριθμων Ταξινόμησης. Εισαγωγή στην Ανάλυση Αλγορίθμων Μάγια Σατρατζέμη Όρια Αλγόριθμων Ταξινόμησης Εισαγωγή στην Ανάλυση Αλγορίθμων Μάγια Σατρατζέμη Όρια Αλγόριθμων Ταξινόμησης Μέχρι στιγμής εξετάσθηκαν μέθοδοι ταξινόμησης µε πολυπλοκότητα της τάξης Θ ) ή Θlog ). Τι εκφράζει

Διαβάστε περισσότερα

Δυναμική Διατήρηση Γραμμικής Διάταξης

Δυναμική Διατήρηση Γραμμικής Διάταξης Διατηρεί μια γραμμική διάταξη δυναμικά μεταβαλλόμενης συλλογής στοιχείων. Υποστηρίζει τις λειτουργίες: Εισαγωγή νέου στοιχείου y αμέσως μετά από το στοιχείο x. x y Διαγραφή στοιχείου y. y Έλεγχος της σειράς

Διαβάστε περισσότερα

Κεφάλαιο 11 Ένωση Ξένων Συνόλων

Κεφάλαιο 11 Ένωση Ξένων Συνόλων Κεφάλαιο 11 Ένωση Ξένων Συνόλων Περιεχόμενα 11.1 Εισαγωγή... 227 11.2 Εφαρμογή στο Πρόβλημα της Συνεκτικότητας... 228 11.3 Δομή Ξένων Συνόλων με Συνδεδεμένες Λίστες... 229 11.4 Δομή Ξένων Συνόλων με Ανοδικά

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

Κεφάλαιο 2. Η δομή δεδομένων Σωρός και η Ταξινόμηση Σωρού (The Heap data structure and Heapsort) Έκδοση 1.3, 14/11/2014

Κεφάλαιο 2. Η δομή δεδομένων Σωρός και η Ταξινόμηση Σωρού (The Heap data structure and Heapsort) Έκδοση 1.3, 14/11/2014 Κεφάλαιο 2 Η δομή δεδομένων Σωρός και η Ταξινόμηση Σωρού (The Heap data structure and Heapsort) Έκδοση 1.3, 14/11/2014 Χρησιμοποιήθηκε υλικό από τις αγγλικές διαφάνειες του Kevin Wayne. 1 Σωρός και Ταξινόμηση

Διαβάστε περισσότερα

ΕΘΝΙΚΟ ΜΕΤΣΟΒΙΟ ΠΟΛΥΤΕΧΝΕΙΟ ΣΧΟΛΗ ΗΛΕΚΤΡΟΛΟΓΩΝ ΜΗΧΑΝΙΚΩΝ ΚΑΙ ΜΗΧΑΝΙΚΩΝ ΥΠΟΛΟΓΙΣΤΩΝ ΤΟΜΕΑΣ ΤΕΧΝΟΛΟΓΙΑΣ ΠΛΗΡΟΦΟΡΙΚΗΣ ΚΑΙ ΥΠΟΛΟΓΙΣΤΩΝ

ΕΘΝΙΚΟ ΜΕΤΣΟΒΙΟ ΠΟΛΥΤΕΧΝΕΙΟ ΣΧΟΛΗ ΗΛΕΚΤΡΟΛΟΓΩΝ ΜΗΧΑΝΙΚΩΝ ΚΑΙ ΜΗΧΑΝΙΚΩΝ ΥΠΟΛΟΓΙΣΤΩΝ ΤΟΜΕΑΣ ΤΕΧΝΟΛΟΓΙΑΣ ΠΛΗΡΟΦΟΡΙΚΗΣ ΚΑΙ ΥΠΟΛΟΓΙΣΤΩΝ ΕΘΝΙΚΟ ΜΕΤΣΟΒΙΟ ΠΟΛΥΤΕΧΝΕΙΟ ΣΧΟΛΗ ΗΛΕΚΤΡΟΛΟΓΩΝ ΜΗΧΑΝΙΚΩΝ ΚΑΙ ΜΗΧΑΝΙΚΩΝ ΥΠΟΛΟΓΙΣΤΩΝ ΤΟΜΕΑΣ ΤΕΧΝΟΛΟΓΙΑΣ ΠΛΗΡΟΦΟΡΙΚΗΣ ΚΑΙ ΥΠΟΛΟΓΙΣΤΩΝ ΟΜΕΣ Ε ΟΜΕΝΩΝ T. Σελλής ΑΝΟΙΞΗ 2003 ΑΣΚΗΣΗ #3 Ηµερ. Παράδοσης: 09/05/03

Διαβάστε περισσότερα

Ειδικά θέματα Αλγορίθμων και Δομών Δεδομένων (ΠΛΕ073) Απαντήσεις 1 ου Σετ Ασκήσεων

Ειδικά θέματα Αλγορίθμων και Δομών Δεδομένων (ΠΛΕ073) Απαντήσεις 1 ου Σετ Ασκήσεων Ειδικά θέματα Αλγορίθμων και Δομών Δεδομένων (ΠΛΕ073) Απαντήσεις 1 ου Σετ Ασκήσεων Άσκηση 1 α) Η δομή σταθμισμένης ένωσης με συμπίεση διαδρομής μπορεί να τροποποιηθεί πολύ εύκολα ώστε να υποστηρίζει τις

Διαβάστε περισσότερα

Union Find, Λεξικό. Δημήτρης Φωτάκης. Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών. Εθνικό Μετσόβιο Πολυτεχνείο

Union Find, Λεξικό. Δημήτρης Φωτάκης. Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών. Εθνικό Μετσόβιο Πολυτεχνείο Union Find, Λεξικό Δημήτρης Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό Μετσόβιο Πολυτεχνείο Διαχείριση Διαμερίσεων Συνόλου Στοιχεία σύμπαντος διαμερίζονται σε κλάσεις ισοδυναμίας

Διαβάστε περισσότερα

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

Δομές Δεδομένων. Καθηγήτρια Μαρία Σατρατζέμη. Τμήμα Εφαρμοσμένης Πληροφορικής. Δομές Δεδομένων. Τμήμα Εφαρμοσμένης Πληροφορικής Ενότητα 8: Γραμμική Αναζήτηση και Δυαδική Αναζήτηση-Εισαγωγή στα Δέντρα και Δυαδικά Δέντρα-Δυαδικά Δέντρα Αναζήτησης & Υλοποίηση ΔΔΑ με δείκτες Καθηγήτρια Μαρία Σατρατζέμη Άδειες Χρήσης Το παρόν εκπαιδευτικό

Διαβάστε περισσότερα

Κεφάλαιο 6 Ουρές Προτεραιότητας

Κεφάλαιο 6 Ουρές Προτεραιότητας Κεφάλαιο 6 Ουρές Προτεραιότητας Περιεχόμενα 6.1 Ο αφηρημένος τύπος δεδομένων ουράς προτεραιότητας... 114 6.2 Ουρές προτεραιότητας με στοιχειώδεις δομές δεδομένων... 115 6.3 Δυαδικός σωρός... 116 6.3.1

Διαβάστε περισσότερα

AVL-trees C++ implementation

AVL-trees C++ implementation Τ Μ Η Μ Α Μ Η Χ Α Ν Ι Κ Ω Ν Η / Υ Κ Α Ι Π Λ Η Ρ Ο Φ Ο Ρ Ι Κ Η Σ AVL-trees C++ implementation Δομές Δεδομένων Μάριος Κενδέα 31 Μαρτίου 2015 kendea@ceid.upatras.gr Εισαγωγή (1/3) Δυαδικά Δένδρα Αναζήτησης:

Διαβάστε περισσότερα

ΗΥ240: οµές εδοµένων Χειµερινό Εξάµηνο Ακαδηµαϊκό Έτος Παναγιώτα Φατούρου. Προγραµµατιστική Εργασία 3 ο Μέρος

ΗΥ240: οµές εδοµένων Χειµερινό Εξάµηνο Ακαδηµαϊκό Έτος Παναγιώτα Φατούρου. Προγραµµατιστική Εργασία 3 ο Μέρος Πανεπιστήµιο Κρήτης, Τµήµα Επιστήµης Υπολογιστών 6 εκεµβρίου 2008 ΗΥ240: οµές εδοµένων Χειµερινό Εξάµηνο Ακαδηµαϊκό Έτος 2008-09 Παναγιώτα Φατούρου Προγραµµατιστική Εργασία 3 ο Μέρος Ηµεροµηνία Παράδοσης:

Διαβάστε περισσότερα

Ισοζυγισµένο έντρο (AVL Tree)

Ισοζυγισµένο έντρο (AVL Tree) Εργαστήριο 7 Ισοζυγισµένο έντρο (AVL Tree) Εισαγωγή Εκτός από τα δυαδικά δέντρα αναζήτησης (inry serh trees) που εξετάσαµε σε προηγούµενο εργαστήριο, υπάρχουν αρκετά είδη δέντρων αναζήτησης µε ξεχωριστό

Διαβάστε περισσότερα

ΕΝΟΤΗΤΑ 9 ΕΝΩΣΗ ΞΕΝΩΝ ΣΥΝΟΛΩΝ ( ΟΜΕΣ UNION-FIND)

ΕΝΟΤΗΤΑ 9 ΕΝΩΣΗ ΞΕΝΩΝ ΣΥΝΟΛΩΝ ( ΟΜΕΣ UNION-FIND) ΕΝΟΤΗΤΑ 9 ΕΝΩΣΗ ΞΕΝΩΝ ΣΥΝΟΛΩΝ ( ΟΜΕΣ UNION-FIND) Ένωση Ξένων Συνόλων (Disjoint Sets with Union) S 1,, S k : ξένα υποσύνολα ενός συνόλου U δηλ., S i S j =, αν i j, και S 1 S k = U. Λειτουργίες που θέλουµε

Διαβάστε περισσότερα

Red-Black Δέντρα. Red-Black Δέντρα

Red-Black Δέντρα. Red-Black Δέντρα Red-Black Δέντρα v 6 3 8 4 z Red-Black Δέντρα Περίληψη Από τα (2,4) δέντρα στα red-black δέντρα Red-black δέντρο Ορισμός Ύψος Εισαγωγή αναδόμηση επαναχρωματισμός Διαγραφή αναδόμηση επαναχρωματισμός προσαρμογή

Διαβάστε περισσότερα