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

Σχετικά έγγραφα
Ενότητα 7 Ουρές Προτεραιότητας

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

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

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

Ενότητα 7 Κατακερµατισµός

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Πελάτες φθάνουν στο ταμείο μιας τράπεζας Eνα μόνο ταμείο είναι ανοικτό Κάθε πελάτης παρουσιάζεται με ένα νούμερο - αριθμός προτεραιότητας Όσο ο

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

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

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

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

Σωροί. Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Ουρές Προτεραιότητας Σωροί υλοποίηση και πράξεις Ο αλγόριθμος ταξινόμησης HeapSort

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

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

Ουρά Προτεραιότητας: Heap

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

Δοµές Δεδοµένων. Αλγόριθµοι & Πολυπλοκότητα (Χειµώνας 2011) Ουρές Προτεραιότητας 2

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

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

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

Ουρά Προτεραιότητας: Heap

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

Ουρά Προτεραιότητας (priority queue)

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

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

Ουρά Προτεραιότητας: Heap

Ουρά Προτεραιότητας: Heap

Αλγόριθμοι Eλάχιστα μονοπάτια

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

Εισαγωγή στους Αλγορίθμους

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

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

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

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

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Ουρές προτεραιότητας Κεφάλαιο 9. Ε. Μαρκάκης Επίκουρος Καθηγητής

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

Θεωρητικό Μέρος. int rec(int n) { int n1, n2; if (n <= 5) then return n; else { n1 = rec(n-5); n2 = rec(n-3); return (n1+n2); } }

Ουρές προτεραιότητας

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

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

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

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

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

Εισαγωγή στους Αλγορίθμους Φροντιστήριο 2

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

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

Δημιουργία Δυαδικών Δέντρων Αναζήτησης

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

Ενότητα 2 Στοίβες Ουρές - Λίστες

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

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

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

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

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

Ουρά Προτεραιότητας (priority queue)

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Ουρές προτεραιότητας Κεφάλαιο 9. Ε. Μαρκάκης Επίκουρος Καθηγητής

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

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

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

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

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

Δυαδικά Δέντρα Αναζήτησης (Binary Search Trees) Ορισμός : Ένα δυαδικό δέντρο αναζήτησης t είναι ένα δυαδικό δέντρο, το οποίο είτε είναι κενό είτε:

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

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

Εισαγωγή στους Αλγορίθμους Ενότητα 3η

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

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

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

ταξινόμηση σωρού Παύλος Εφραιμίδης Δομές Δεδομένων και

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

Δοµές Δεδοµένων. 14η Διάλεξη Δέντρα Δυαδικής Αναζήτησης. Ε. Μαρκάκης

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

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

AVL-trees C++ implementation

Transcript:

Ενότητα 7 Ουρές Προτεραιότητας ΗΥ240 - Παναγιώτα Φατούρου Ουρές Προτεραιότητας Θεωρούµε ένα χώρο κλειδιών U και έστω ότι µε κάθε κλειδί Κ (τύπου Key) έχει συσχετισθεί κάποια πληροφορία Ι (τύπου Type). Έστω ότι έχει ορισθεί µια διάταξη στα στοιχεία του U έτσι ώστε για κάθε ζεύγος στοιχείων x,y U, να ισχύει είτε x = y ή x < y ή x > y. Τα στοιχεία που είναι επιθυµητό να αποθηκευθούν στη δοµή είναι ζεύγη της µορφής <Κ,Ι>. ΗΥ240 - Παναγιώτα Φατούρου 2

Ουρές Προτεραιότητας Μια ουρά προτεραιότητας είναι ένας αφηρηµένος τύπος δεδοµένων για ένα σύνολο µε στοιχεία ζεύγη <Κ,Ι>, που υποστηρίζει τις ακόλουθες λειτουργίες: q MakeEmptySet(): επιστρέφει το κενό σύνολο. q IsEmptySet(S): Επιστρέφει true αν S =, false διαφορετικά q Insert(K,I,S): Εισάγει το ζεύγος <Κ,Ι> στο S. q FindMin(S): Eπιστρέφει το πεδίο I του ζεύγους <Κ,Ι>, όπου Κ είναι το µικρότερο κλειδί στο σύνολο. q DeleteMin(S): Διαγράφει το ζεύγος <Κ,Ι>, όπου Κ είναι το µικρότερο κλειδί στο σύνολο, και επιστρέφει Ι. ΗΥ240 - Παναγιώτα Φατούρου 3 Ουρές Προτεραιότητας Υλοποίηση µε Ισοζυγισµένα Δένδρα Μπορούµε να υλοποιήσουµε µια ουρά προτεραιότητας µε ισοζυγισµένα δένδρα; AVL δένδρα, 2-3 δένδρα, κοκκινόµαυρα δένδρα: όλα παρέχουν αποτελεσµατικές υλοποιήσεις ουρών προτεραιοτήτων. Δεδοµένου ενός ισοζυγισµένου δένδρου, πως θα µπορούσαµε να υλοποιήσουµε µια ουρά προτεραιότητας; Ποια είναι η χρονική πολυπλοκότητα για τις λειτουργίες Insert(), FindMin() και DeleteMin(); Υπάρχουν άλλες λειτουργίες που να υποστηρίζονται αποδοτικά; () LookUp; (2) Delete; (3) FindMax DeleteMax; Μια ουρά προτεραιότητας που υποστηρίζει και τις λειτουργίες FindMax() και DeleteMax() ονοµάζεται διπλή ουρά προτεραιότητας (ή ουρά προτεραιότητας µε δύο άκρα). ΗΥ240 - Παναγιώτα Φατούρου 4 2

Ουρές Προτεραιότητας Ένα µερικώς διατεταγµένο δένδρο είναι ένα δυαδικό δένδρο του οποίου τα στοιχεία έχουν την εξής ιδιότητα: Το κλειδί κάθε κόµβου είναι µικρότερο ή ίσο εκείνου των παιδιών του κόµβου. Σχήµα 9.: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 99 Θεωρούµε ότι η προτεραιότητα ενός κόµβου καθορίζεται από το κλειδί του ως εξής: µικρό κλειδί -> µεγάλη προτεραιότητα και το αντίστροφο. Ποιος είναι ο κόµβος µε τη µεγαλύτερη προτεραιότητα σε ένα µερικώς διατεταγµένο δένδρο; " Σε κάθε µονοπάτι από τη ρίζα προς οποιοδήποτε κόµβο, οι κόµβοι που διατρέχουµε είναι φθίνουσας προτεραιότητας. Πως υλοποιούµε την FindMin() σε µερικώς διατεταγµένο δένδρο; ΗΥ240 - Παναγιώτα Φατούρου 5 Ουρές Προτεραιότητας Σχήµα 9.2(α): Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 99 Προκειµένου οι λειτουργίες που υποστηρίζονται από µια ουρά προτεραιότητας να υλοποιηθούν αποδοτικά, θα ήταν επιθυµητό το ύψος του δένδρου να είναι O(log n). DeleteMin() Δεν διαγράφουµε τη ρίζα, αλλά το δεξιότερο φύλλο του τελευταίου επιπέδου του δένδρου, αφού πρώτα αντιγράψουµε τα δεδοµένα του στη ρίζα. Πρόβληµα που µπορεί να προκύψει Το προκύπτον δένδρο µπορεί να µην είναι µερικώς διατεταγµένο δένδρο. Παρατήρηση Η µερική διάταξη καταστρέφεται µόνο στη ρίζα. ΗΥ240 - Παναγιώτα Φατούρου 6 3

Μερικώς Διατεταγµένα Δένδρα Διαγραφή DeleteMin() - Επανόρθωση διάταξης. Έστω u η ρίζα του δένδρου και w o θυγατρικός κόµβος του u µε το µικρότερο κλειδί. 2. Αν (w == nill OR κλειδί του u < κλειδί του w) ο αλγόριθµος τερµατίζει; 3. Ανταλλάσσουµε τα δεδοµένα <Κ,Ι> του u µε τα δεδοµένα <Κ,Ι > του w; 4. Θέτουµε (u = w) και (w = θυγατρικός κόµβος του u µε το µικρότερο κλειδί); 5. Επιστρέφουµε στο βήµα 2; Ποια είναι πολυπλοκότητα της DeleteMin(); O(ύψος δένδρου) Σχήµα 9.2: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 99 ΗΥ240 - Παναγιώτα Φατούρου 7 Μερικώς Διατεταγµένα Δένδρα Σχήµα 9.3: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 99 Insert() q Εισάγουµε το νέο στοιχείο ως δεξιότερο φύλλο του δένδρου. q Η ιδιότητα της µερικής διάταξης ίσως καταστρέφεται άλλα µόνο για τον πατέρα του φύλλου αυτού. ΗΥ240 - Παναγιώτα Φατούρου 8 4

Μερικώς Διατεταγµένα Δένδρα Insert() - Επανόρθωση διάταξης. Έστω u ο κόµβος φύλλο στον οποίο γίνεται η εισαγωγή και w o πατρικός κόµβος του u. 2. Αν (w == nill OR κλειδί του w < κλειδί του u) ο αλγόριθµος τερµατίζει; 3. Ανταλλάσσουµε τα δεδοµένα <Κ,Ι> του u µε τα δεδοµένα (<Κ,Ι >) του w; 4. Θέτω (u = w) και (w = πατρικός κόµβος του u); 5. Επιστρέφουµε στο βήµα 2; Σχήµα 9.3: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 99 Ποια είναι η χρονική πολυπλοκότητα της Insert(); Ο(ύψος δένδρου) ΗΥ240 - Παναγιώτα Φατούρου 9 Μερικώς Διατεταγµένα Δένδρα Υλοποίηση ως Πλήρη Δυαδικά Δένδρα 0 2 3 4 5 6 7 8 9 0 5 8 9 6 2 0 56 8 20 22 44 " Υλοποιούµε το µερικώς διατεταγµένο δένδρο χρησιµοποιώντας πλήρη δυαδικά δένδρα. " Το δεξιότερο φύλλο µε µέγιστο βάθος στο δένδρο είναι το τελευταίο στοιχείο του πίνακα. " Η θέση του πίνακα που περιέχει αυτό τον κόµβο µπορεί να καθοριστεί αν γνωρίζουµε το πλήθος των στοιχείων και τη διεύθυνση του πρώτου στοιχείου του πίνακα. " Η διαγραφή του φύλλου αυτού δεν επηρεάζει την µερική διάταξη του δένδρου, ενώ το δένδρο εξακολουθεί να είναι πλήρες. ΗΥ240 - Παναγιώτα Φατούρου 0 5

Μερικώς Διατεταγµένα Δένδρα Υλοποίηση ως Πλήρη Δυαδικά Δένδρα Ένα µερικώς διατεταγµένο δένδρο υλοποιηµένο µε στατικό τρόπο (δηλαδή µε πίνακα), ονοµάζεται σωρός. Το ύψος οποιουδήποτε πλήρους δυαδικού δένδρου είναι O(logn) Πολυπλοκότητα HeapInsert() και HeapDeleteMin() = O(logn). 0 2 3 4 5 6 7 8 9 0 5 8 9 6 2 0 56 8 20 22 44 Ο σωρός είναι µια εξαιρετικά αποδοτική δοµή για την υλοποίηση ουρών προτεραιότητας! ΗΥ240 - Παναγιώτα Φατούρου Υλοποίηση Πλήρων Δυαδικών Δένδρων Υπάρχει µόνο ένα πλήρες δυαδικό δένδρο µε n κόµβους και το υλοποιούµε µε ένα πίνακα N στοιχείων. Αριθµούµε τους κόµβους µε αριθµούς στο διάστηµα {0,...,n- και αποθηκεύουµε τον κόµβο i στο στοιχείο Τ[i] του πίνακα. Θέλουµε να κάνουµε την αρίθµηση µε τέτοιο τρόπο ώστε να πετύχουµε την εκτέλεση χρήσιµων λειτουργιών στο δένδρο σε σταθερό χρόνο. ΗΥ240 - Παναγιώτα Φατούρου 2 3 G D 4 5 K 6 7 8 9 0 i 2i+ 0 2 3 4 5 6 7 8 9 0 Αρίθµηση Α C E G D K X B O M Y s Η ρίζα είναι ο κόµβος 0. Το αριστερό παιδί του κόµβου i αριθµείται ως κόµβος 2i+, ενώ το δεξί παιδί του ως κόµβος 2i+2. Υλοποίηση Λειτουργιών q IsLeaf(i): return (2i+ n); q LeftChild(i): if (2i+ < n); return (2i+) else return nill; q RightChild(i): if (2i+2<n) return(2i+2); else return nill; q LeftSibling(i): if (i!= 0 and i not odd) return (i-); q RightSibling(i): if (i!= n- and i not even) return(i+); q Parent(i): if (i!= 0) return( (i-)/2 ); C A 0 B O M Y S E 2 Χρονική πολυπλοκότητα κάθε λειτουργίας: Θ() X 6

Σωροί Ψευδοκώδικας για HeapInsert() q Ο σωρός υλοποιείται από έναν πίνακα A (τύπου HeapTable) και έναν ακέραιο size που υποδηλώνει το πλήθος των στοιχείων του σωρού. procedure HeapInsert(HeapTable A, int size, Key K, Type I) { /* Εισαγωγή του ζεύγους <K,I> στο σωρό <A,size> 0 */ if (size == N) then error; /* Heap is full */ m = size; // o m είναι ακέραιος που χρησιµοποιείται ως δείκτης // στους κόµβους ενός µονοπατιού του δένδρου. // Αρχικά, δείχνει στη θέση που θα εισαχθεί το νέο στοιχείο while (m > 0 and K < Α[ (m-)/2 ]->Key) { 3 4 // όσο δεν έχω φθάσει στη ρίζα και // o πατρικός κόµβος του m έχει µικρότερο κλειδί από το K Α[m]->key = Α[ (m-)/2 ]->Key; // το κλειδί και τα δεδοµένα του πατρικού κόµβου Α[m]->data = Α[ (m-)/2 ]->data; // του m αντιγράφονται στον m m = (m-)/2 ; // η διαδικασία επαναλαµβάνεται µε m = πατρικός κόµβος του m 5 9 0 2 3 4 5 6 7 8 9 0 Α[m]->Key = K; 5 8 9 6 2 0 56 8 20 22 44 0 Α[m]->data = I; size++; Παράδειγµα: Εισαγωγή 8 9 ΗΥ240 - Παναγιώτα Φατούρου m =, 5, 2, 0 3 7 0 5 2 6 Σωροί Ψευδοκώδικας για HeapDeleteMin() Type HeapDeleteMin(HeapTable A, int size) { // διαγραφή του στοιχείου µε τη µεγαλύτερη προτεραιότητα και επιστροφή της τιµής του if (size == 0) then error; // Κενός σωρός I = A[0]->data; // Στοιχείο που θα επιστραφεί K = A[size-]->Key; // τιµή κλειδιού που θα µετακινηθεί προς τη ρίζα size--; // νέο µέγεθος σωρού if (size == ) then return; // ο σωρός περιέχει µόνο τη ρίζα µετά τη διαγραφή m = 0; /* ο m είναι ακέραιος που δεικτοδοτεί τους κόµβους ενός µονοπατιού while ((2m+ < size AND K > A[2m+]->Key) OR // αν υπάρχει αριστερό παιδί και έχει µικρότερο κλειδί (2m+2 < size AND K > A[2m+2]->Key)) { // ή αν υπάρχει δεξιό παιδί και έχει µικρότερο κλειδί if (2m +2 < size) { // o m έχει δύο θυγατρικούς κόµβους if (A[2m+]->Key < A[2m+2]->Key) p = 2m+; // ο p δείχνει στο θυγατρικό του m µε το µεγαλύτερο κλειδί else p = 2m+2; 0 2 else p = size-; A[m]->Key = A[p]->Key; 3 4 5 6 A[m]->data = A[p]->data; m = p; A[m]->Key = K; A[m]->data = A[size]->data; return I; 7 8 9 0 44 8 2 22 0 2 3 4 5 6 7 8 9 0 5 8 9 6 2 0 56 8 20 22 44 Παράδειγµα: DeleteMin() ΗΥ240 - Παναγιώτα Φατούρου 4 m = 0,, 4, 9 7

Αναφορές Το υλικό της ενότητας αυτής περιέχεται στo ακόλουθo βιβλίo: n Harry Lewis and Larry Denenberg, Data Structures and Their Algorithms, Harper Collins Publishers, Inc., New York, 99 Chapter 9: Sets with special operations ΗΥ240 - Παναγιώτα Φατούρου 5 8