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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Λεξικό, Union Find. ιδάσκοντες: Σ. Ζάχος,. Φωτάκης Επιμέλεια διαφανειών:. Φωτάκης. Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών

Λεξικό, Union Find. ιδάσκοντες: Σ. Ζάχος,. Φωτάκης Επιμέλεια διαφανειών:. Φωτάκης. Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών

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

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

Λεξικό, Union Find. ιδάσκοντες: Σ. Ζάχος,. Φωτάκης Επιμέλεια διαφανειών:. Φωτάκης. Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών

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

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

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

Λεξικό, Union Find. ιδάσκοντες: Σ. Ζάχος,. Φωτάκης Επιμέλεια διαφανειών:. Φωτάκης. Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Συνδετικότητα γραφήματος (graph connectivity)

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

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

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

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

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

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

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

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

Θεωρητικό Μέρος. 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); } }

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

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

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

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

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

Επίλυση Προβληµάτων µε Greedy Αλγόριθµους

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

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

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

Δοµές Δεδοµένων. 11η Διάλεξη Ταξινόµηση Quicksort και Ιδιότητες Δέντρων. Ε. Μαρκάκης

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

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

Ταξινόμηση με συγχώνευση Merge Sort

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

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

Κατανεμημένα Συστήματα Ι

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

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

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

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

Κεφάλαιο 7 Λεξικά και Δυαδικά Δένδρα Αναζήτησης

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

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

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

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

Διασυνδεδεμένες Δομές. Δυαδικά Δέντρα. Προγραμματισμός II 1

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

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

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

Αλγόριθμοι Ταξινόμησης Μέρος 4

Αλγόριθμοι Ταξινόμησης Μέρος 3

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

d k 10 k + d k 1 10 k d d = k i=0 d i 10 i.

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

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

Αναδροµή. Σε αυτήν την (βοηθητική) ενότητα θα µελετηθούν τα εξής : Η έννοια της αναδροµής Υλοποίηση και αποδοτικότητα Αφαίρεση της αναδροµής

Transcript:

Ενότητα 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): επιστρέφει ένα νέο σύνολο που περιέχει µόνο το στοιχείο X q Union(S,T): επιστρέφει το σύνολο S T, το οποίο αντικαθιστά τα S, T q Find(X): επιστρέφει το σύνολο S στο οποίο ανήκει το στοιχείο Χ ΗΥ240 - Παναγιώτα Φατούρου 2 1

Εφαρµογές q Το πρόβληµα της διαχειρίσεως ξένων µεταξύ τους συνόλων εµφανίζεται σε αρκετές εφαρµογές. Υπάρχουν αλγόριθµοι ευρέσεως σκελετικών δένδρων (spanning trees) που ξεκινούν από n στοιχειώδη σκελετικά δένδρα µε έναν κόµβο το καθένα και βήµα προς βήµα συνενώνουν ξένα µεταξύ τους σκελετικά υποδένδρα µέχρι να προκύψει τελικά ένα δένδρο που αποτελεί το προς αναζήτηση σκελετικό δένδρο. ΗΥ240 - Παναγιώτα Φατούρου 3 Ξένα Σύνολα µε τη Up-Tree q Είναι δένδρο στο οποίο κάθε κόµβος διατηρεί µόνο ένα δείκτη προς τον πατρικό του κόµβο (έτσι όλοι οι δείκτες δείχνουν προς τα πάνω). q Ένας κόµβος µπορεί να έχει οποιοδήποτε πλήθος παιδιών. q Το σύνολο U υλοποιείται ως ένα δάσος από Up-trees. q Κάθε τέτοιο δένδρο περιέχει τα στοιχεία ενός από τα ξένα σύνολα. Το στοιχείο της ρίζας αποτελεί το αναγνωριστικό του συνόλου. Υλοποίηση Find(X), όπου X είναι ένας δείκτης σε ένα κόµβο Ακολούθησε τους δείκτες από τον κόµβο προς τη ρίζα. Ποια είναι η πολυπλοκότητα της Find(); Σχήµα 9.5 (a): Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 1991 Ο(ύψος δένδρου) ΗΥ240 - Παναγιώτα Φατούρου 4 2

λειτουργία της Ένωσης Έλεγχος αν ένα στοιχείο Χ ανήκει στο σύνολο S Ελέγχουµε αν η Find(X) επιστρέφει S. Υλοποίηση Union(S,T) Κάνε τη ρίζα του ενός δένδρου να δείχνει στη ρίζα του άλλου. Ποια είναι η πολυπλοκότητα της Union(); Σχήµα 9.5 (b) & (c): Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 1991 Ο(1) " Είναι επιθυµητό το ύψος του δένδρου να είναι όσο το δυνατό µικρότερο q Χρειάζεται προσοχή στην επιλογή του δένδρου του οποίου η ρίζα θα δείξει στη ρίζα του άλλου! ΗΥ240 - Παναγιώτα Φατούρου 5 Παράδειγµα Έστω ότι έχουµε n σύνολα µε ένα στοιχείο το καθένα. Ποιο είναι το χειρότερο ύψος δένδρου που µπορεί να προκύψει και πως πρέπει να εκτελεστεί η Union() για να προκύψει ένα τέτοιο δένδρο; S 1 S 2 S 3 S 4 S 5 Στρατηγική για µείωση ύψους δένδρου «Πάντα συνενώνουµε το µικρότερο δένδρο στο µεγαλύτερο, δηλαδή κάνουµε τη ρίζα του µικρότερου δένδρου να δείχνει στη ρίζα του µεγαλύτερου δένδρου». Ένα δένδρο είναι µεγαλύτερο από ένα άλλο αν έχει περισσότερους κόµβους. S 2 S 3 S 4 S 5 ΗΥ240 - Παναγιώτα Φατούρου S 1 6 3

Κάθε κόµβος είναι ένα struct µε πεδία κάποια πληροφορία για το στοιχείο, το δείκτη parent στο γονικό κόµβο, και ένα µετρητή count, που χρησιµοποιείται µόνο αν ο κόµβος είναι η ρίζα και περιέχει το πλήθος των κόµβων στο up-tree. pointer UpTreeFind(pointer P) { // return the root of the tree containing P } if (P == NULL) error; q = P; while (q->parent!= NULL) do q = q->parent return q; ΗΥ240 - Παναγιώτα Φατούρου 7 pointer UpTreeUnion(pointer S,T) { // S and T are roots of up-trees */ // returns result of merging smaller into larger if (S == NULL OR P == NULL) return; if (S->count >= T->count) { S->count = S->count + T->count; T->parent = S; return S; } else { T->count = T->count + S->count; S->parent = T; return T; } } ΗΥ240 - Παναγιώτα Φατούρου 8 4

Λήµµα Έστω ότι T είναι ένα up-tree που αναπαριστά ένα σύνολο µεγέθους n, το οποίο δηµιουργήθηκε µε τη συνένωση n συνόλων µεγέθους 1 χρησιµοποιώντας την UPTreeUnion(). Τότε, το ύψος του T είναι το πολύ log n. Απόδειξη: Αποδεικνύουµε ότι για κάθε h, αν το Τ είναι up-tree ύψους h που δηµιουργήθηκε από τη συνένωση n συνόλων µεγέθους 1 (εκτελώντας επαναληπτικά την UpTreeUnion()), τότε το Τ έχει τουλάχιστον 2 h κόµβους, δηλαδή Τ 2 h. Με επαγωγή στο h. Βάση Επαγωγής (h=0): Τότε το Τ αποτελείται από έναν µόνο κόµβο Τ = 1 2 0. Επαγωγική Υπόθεση: Υποθέτουµε πως για κάθε up-tree S, αν το ύψος h του S είναι h, τότε S 2 h. ΗΥ240 - Παναγιώτα Φατούρου 9 λειτουργία της Ένωσης Επαγωγικό Βήµα: Συµβολίζουµε µε Τ το πρώτο δένδρο που δηµιουργείται µε ύψος h+1 (εφαρµόζοντας τον παραπάνω αλγόριθµο). Τότε, το Τ δηµιουργείται µε τη συνένωση ενός up-tree Τ 2 σε ένα uptree Τ 1 για τα οποία ισχύουν τα εξής: το Τ 2 έχει ύψος h, ενώ το Τ 1 έχει ύψος το πολύ h και Τ 1 Τ 2. Από επαγωγική υπόθεση, Τ 2 2 h. Εποµένως, Τ = Τ 1 + Τ 2 2* Τ 2 2*2 h = 2 h+1. Συµπεραίνουµε εποµένως ότι: n = Τ 2 h+1 h log n - 1 νέα ακµή δένδρο µε λιγότερους κόµβους Σχήµα 9.6: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 1991 ΗΥ240 - Παναγιώτα Φατούρου 10 5

Ποια είναι η πολυπλοκότητα της Find(X); H Find(X) εµπεριέχει µια LookUp(). Πως θα υλοποιήσουµε αυτή τη LookUp; Περιπτώσεις 1. Ο χώρος των κλειδιών είναι µικρός και τα κλειδιά έχουν µικρές τιµές. Τότε, είναι εφικτό να αποθηκευτούν αυτά σε έναν πίνακα 100 θέσεων του οποίου η θέση i περιέχει δείκτη προς το κλειδί i (ή NULL αν το κλειδί i δεν ανήκει στο U), οπότε η LookUp() υλοποιείται σε σταθερό χρόνο. 2. Ο χώρος των κλειδιών είναι µεγάλος. Τότε, απαιτείται µια βοηθητική δοµή (π.χ., µια από τις δενδρικές δοµές που υλοποιούν λεξικά) που η πληροφορία κάθε κόµβου είναι δείκτης σε ένα από τα κλειδιά του up-tree. Σχήµα 9.7: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 1991 ΗΥ240 - Παναγιώτα Φατούρου 11 To 2-3 δένδρο περιέχει όλα τα κλειδιά του up-tree εκτός από το µεγαλύτερο. Κάθε κλειδί του 2-3 δένδρου έχει συσχετισθεί µε έναν δείκτη προς κάποιο κόµβο του up-tree. Για τα κλειδιά που είναι αποθηκευµένα σε κόµβους φύλλα, ο δείκτης αυτός είναι ο δείκτης που βρίσκεται στα αριστερά τους. Ποια είναι η πολυπλοκότητα της Find() µε τα νέα δεδοµένα; Ο(logn) Για τα κλειδιά που είναι αποθηκευµένα σε εσωτερικούς κόµβους, ο δείκτης αυτός είναι ο δείκτης στα δεξιά του προηγούµενού τους στην ενδοδιατεγµένη διάταξη. Ο δείκτης στα δεξιά του Η δείχνει στον κόµβο µε το µεγαλύτερο κλειδί στο up-tree. ΗΥ240 - Παναγιώτα Φατούρου 12 6

Σχήµα 9.8: Lewis & Denenberg, Data Structures & Their Algorithms, Addison-Wesley, 1991 Στρατηγική Συµπίεσης Μονοπατιού «Κατά τη διάρκεια εκτέλεσης µιας Find(Χ), το parent πεδίο κάθε κόµβου στο µονοπάτι που ακολουθείται από τον κόµβο µε κλειδί Χ στη ρίζα, αλλάζει ώστε να δείχνει στη ρίζα». Αποτέλεσµα Find(D) όταν χρησιµοποιείται η στρατηγική συµπίεσης µονοπατιού. ΗΥ240 - Παναγιώτα Φατούρου 13 Τι αλλαγές επιφέρει η στρατηγική συµπίεσης µονοπατιού στην απόδοση? Οι MakeEmptySet() και Union() εξακολουθούν να χρειάζονται σταθερό χρόνο. Η Find() αρχικά εκτελείται στον ίδιο ακριβώς χρόνο όπως χωρίς να εφαρµόζεται η στρατηγική, αλλά µετά την εκτέλεση αρκετών Find(), η πολυπλοκότητά της γίνεται «σχεδόν σταθερή». Αποτέλεσµα Find(D) όταν χρησιµοποιείται η στρατηγική συµπίεσης µονοπατιού. ΗΥ240 - Παναγιώτα Φατούρου 14 7

λειτουργία της Ένωσης Για κάθε j, έστω F(j) η αναδροµική συνάρτηση που ορίζεται ως εξής: F(0) = 1 και F(j+1) = 2 F(j), j 0. Οι τιµές της F(j) αυξάνουν πάρα πολύ γρήγορα καθώς αυξάνεται το j, π.χ., για j = 5, Φ(5) = 2 65536 10 19728. Ο αριθµός αυτός είναι πολύ µεγάλος (η διάµετρος του σύµπαντος είναι 10 40 και το πλήθος µορίων σε ολόκληρο το σύµπαν είναι µικρότερο από 10 120 ). Ορίζουµε την log*n ως εξής: log*n = το ελάχιστο i τ.ω. F(i) n = το ελάχιστο i τ.ω. log log log log n 1 i φορές Οι τιµές της log*n αυξάνονται πάρα πολύ αργά καθώς αυξάνει το n, π.χ., log*n είναι 5 για οποιαδήποτε «χρήσιµη» τιµή του n. Αν η Find() εκτελείται σε χρόνο Ο(log*n) είναι εποµένως σαν να είναι σταθερής πολυπλοκότητας. ΗΥ240 - Παναγιώτα Φατούρου 15 Αναφορές Το υλικό της ενότητας αυτής περιέχεται στo ακόλουθo βιβλίo: Harry Lewis and Larry Denenberg, Data Structures and Their Algorithms, Harper Collins Publishers, Inc., New York, 1991 Section 9.2: Disjoint Sets with Union ΗΥ240 - Παναγιώτα Φατούρου 16 8