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

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

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

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

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

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

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

Cuckoo Hashing. Αλγόριθμοι και Πολυπλοκότητα. Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό Μετσόβιο Πολυτεχνείο

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

Αναδρομικές Σχέσεις «ιαίρει-και-βασίλευε»

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

Αλγόριθμοι Αναζήτησης

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

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

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

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

Διαίρει-και-Βασίλευε. Διαίρει-και-Βασίλευε. MergeSort. MergeSort. Πρόβλημα Ταξινόμησης: Είσοδος : ακολουθία n αριθμών (α 1

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

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

Quicksort. Πρόβλημα Ταξινόμησης. Μέθοδοι Ταξινόμησης. Συγκριτικοί Αλγόριθμοι

Επιλογή. Πρόβλημα Επιλογής. Μέγιστο / Ελάχιστο. Εφαρμογές

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

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

Quicksort. Επιμέλεια διαφανειών: Δ. Φωτάκης Μικροαλλαγές: Α. Παγουρτζής. Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών

Αναζήτηση Κατά Πλάτος

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

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

έντρα Πολλαπλής ιακλάδωσης και (a, b)- έντρα

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

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

Ασυμπτωτικός Συμβολισμός

Αναζήτηση Κατά Πλάτος

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

Βασικές Έννοιες Θεωρίας Γραφημάτων

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

ιµελής Σχέση ιατεταγµένο ζεύγος (α, β): ύο αντικείµενα (όχι κατ ανάγκη διαφορετικά) σε καθορισµένη σειρά. Γενίκευση: διατεταγµένη τριάδα (α, β, γ), δι

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

Συντομότερες ιαδρομές

Δυναμικός Κατακερματισμός. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

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

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

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

Ελάχιστο Συνδετικό έντρο

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

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

Μετασχηματισμοί, Αναπαράσταση και Ισομορφισμός Γραφημάτων

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

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

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

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

Διαίρει-και-Βασίλευε. Αλγόριθµοι & Πολυπλοκότητα (Χειµώνας 2011) Διαίρει-και-Βασίλευε 2

Ασυμπτωτικός Συμβολισμός

Μέγιστη Ροή Ελάχιστη Τομή

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

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

Αναζήτηση Κατά Πλάτος

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

Δυναμικός Κατακερματισμός. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

Αναζήτηση Κατά Πλάτος

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

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

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

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

Πληροφορική 2. Δομές δεδομένων και αρχείων

Δυναμικός Προγραμματισμός

Ελάχιστο Συνδετικό Δέντρο

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

Δυναμικός Κατακερματισμός. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

Αναζήτηση Κατά Βάθος. ιδάσκοντες: Σ. Ζάχος,. Φωτάκης Επιμέλεια διαφανειών:. Φωτάκης. Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών

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

Ελάχιστο Συνδετικό Δέντρο

Κατακερµατισµός. Οργάνωση Αρχείων (σύνοψη) Οργάνωση αρχείων: πως είναι τοποθετημένες οι εγγραφές ενός αρχείου όταν αποθηκεύονται στο δίσκο

Βασικές Έννοιες Θεωρίας Γραφημάτων

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

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

Συντομότερες ιαδρομές

Ανάλυση αλγορίθμων. Χρόνος εκτέλεσης: Αναμενόμενη περίπτωση. - απαιτεί γνώση της κατανομής εισόδου

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

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

Το εσωτερικό ενός Σ Β

Τι είναι αλγόριθμος; Υποπρογράμματα (υποαλγόριθμοι) Βασικές αλγοριθμικές δομές

Τα δεδομένα (περιεχόμενο) μιας βάσης δεδομένων αποθηκεύεται στο δίσκο

Συντομότερες ιαδρομές

Συντομότερες Διαδρομές

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

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

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

Δυναμικός Κατακερματισμός. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

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

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

Αναζήτηση Κατά Βάθος. ιδάσκοντες: Σ. Ζάχος,. Φωτάκης Επιμέλεια διαφανειών:. Φωτάκης. Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών

8. Σωροί (Heaps)-Αναδρομή- Προχωρημένη Ταξινόμηση

Μέγιστη Ροή Ελάχιστη Τομή

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

Πρόβληµα Επιλογής. Αλγόριθµοι & Πολυπλοκότητα (Χειµώνας 2011) Επιλογή 1

(Γραμμικές) Αναδρομικές Σχέσεις

Ασυμπτωτικός Συμβολισμός

Πιθανοτικοί Αλγόριθμοι

Ελάχιστο Συνδετικό έντρο

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

Σχέση Μερικής ιάταξης Σχέση Μερικής ιάταξης (ή µερική διάταξη): ανακλαστική, αντισυµµετρική, και µεταβατική. Αριθµοί: α β (αλλά όχι α < β), α β, Σύνολ

Transcript:

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

Πρόβλημα (ADT) Λεξικού υναμικά μεταβαλλόμενη συλλογή αντικειμένων που αναγνωρίζονται με «κλειδί» (π.χ. κατάλογοι, πίνακες Β ). Λεξικό : συλλογή αντικειμένων με μοναδικό «κλειδί». «Κλειδί»: αριθμός ήτύποςδεδομένωνμεολική διάταξη. Γενίκευση και για μη-μοναδικά κλειδιά. ADT λεξικού υποστηρίζει ακολουθίες λειτουργιών: Αναζήτηση στοιχείου με κλειδί x member(x): ελέγχει ύπαρξη στοιχείου με κλειδί x search(x): επιστρέψει δείκτη σε θέσεις x Εισαγωγή στοιχείου με κλειδί x ιαγραφή στοιχείου με κλειδί x Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2012) Λεξικό, Union - Find 2

Λειτουργίες Λεξικού Λεξικό υποστηρίζει λειτουργίες: Αναζήτηση/εισαγωγή/διαγραφή στοιχείου με κλειδί x Εκτύπωση στοιχείων σε αύξουσα / φθίνουσα σειρά Προηγούμενο και επόμενο στοιχείο. Μέγιστο και ελάχιστο στοιχείο. k-οστό μικρότερο στοιχείο Βοηθητικές λειτουργίες... Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2012) Λεξικό, Union - Find 3

Υλοποιήσεις Λεξικού Μη-ταξινομημένη διασυνδεδεμένη λίστα: Εισαγωγή: Ο(1) Αναζήτηση / τυχαία διαγραφή: Ο(n) Κατάλληλη όταν συχνές εισαγωγές, σπάνιες αναζητήσεις / διαγραφές μεμονωμένες ή στο τέλος (π.χ. log file). Ταξινομημένος πίνακας: ( υαδική) αναζήτηση: Ο(log n) Στατική συλλογή : «εισαγωγή» Ο(log n) / στοιχείο Χρόνος ταξινόμησης : Ο(n log n) υναμική συλλογή : εισαγωγή / διαγραφή Ο(n) Κατάλληλη όταν συχνές αναζητήσεις και δεδομένα μεταβάλλονται σπάνια (π.χ. αγγλο-ελληνικό λεξικό). Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2012) Λεξικό, Union - Find 4

Υλοποιήσεις Λεξικού Ζυγισμένο ( υαδικό) έντρο Αναζήτησης: Αναζήτηση / εισαγωγή / διαγραφή: Ο(log n) Μέγιστο / ελάχιστο / προηγούμενο / επόμενο / k-οστό: Ο(log n) Range queries σε γραμμικό χρόνο. Πλήρως δυναμική επιπλέον χώρος για δείκτες! Πίνακας Κατακερματισμού (hashing): Αναζήτηση / διαγραφή : Ο(1) Εισαγωγή : Ο(1) expected amortized, Ο(log n) (ακόμη και Ο(1)) whp., O(n) χ.π. εν υποστηρίζει αποδοτικά άλλες λειτουργίες. υναμική επιπλέον χώρος στον πίνακα (util 50%) Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2012) Λεξικό, Union - Find 5

ιαχείριση ιαμερίσεων Συνόλου Στοιχεία σύμπαντος διαμερίζονται σε κλάσεις ισοδυναμίας που μεταβάλλονται δυναμικά με ένωση. Λειτουργίες: Εύρεση find(x): αντιπρόσωπο κλάσης όπου ανήκει x. Ένωση union(x, y): ένωση κλάσεων όπου ανήκουν x και y. Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2012) Λεξικό, Union - Find 6

Πρόβλημα Union Find Στοιχεία U = {1, 2,, n} αρχικά σε n κλάσεις. Κάθε κλάση προσδιορίζεται από στοιχείο αντιπρόσωπο. find(x): αντιπρόσωπος κλάσης όπου ανήκει x. ιατηρούμε μοναδικό αντιπρόσωπο για κάθε κλάση. union(x, y): αντικατάσταση (αντιπροσώπων) κλάσεων x και y με κλάση που προκύπτει από ένωση. Ελέγχουμε αν x και y ανήκουν σε διαφορετική κλάση. Νέος αντιπρόσωπος από τους αντιπροσώπους κλάσεων x, y Πάντα διαμέριση του U σε κλάσεις. n 1 ενώσεις (μετά από n 1, μία μόνο κλάση). ομή δεδομένων που ελαχιστοποιεί συνολικό χρόνο για ακολουθία m ευρέσεων και n 1 ενώσεων. Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2012) Λεξικό, Union - Find 7

Αναπαράσταση έντρου & άσους Πίνακας γονέων Α[1...n] για δέντρο με ρίζα και n κόμβους: Α[i] = j ανν j πατέρας του i στο δέντρο. Α[ρίζας] = ρίζα (ή -1). Όμοια για δάσος όπου κάθε δέντρο έχει ρίζα. Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2012) Λεξικό, Union - Find 8

Αναπαράσταση με έντρα Κλάση: δέντρο με ρίζα το στοιχείο-αντιπρόσωπο. Όνομα ρίζας. Μέγεθος κλάσης. Στοιχείο: κόμβος δέντρου με πεδία Όνομα στοιχείου. Όνομα γονέα: όνομα προηγούμενου στοιχείου στο μονοπάτι προς τη ρίζα-αντιπρόσωπο. Αναπαράσταση με πίνακα γονέων: A[x] : γονέας στοιχείου x. Ρίζα στοιχείο αντιπρόσωπος έχει Α[x] = x και επιπλέον πεδίο size. Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2012)

Αναπαράσταση με έντρα find(x): ακολουθούμε δείκτες σε γονέα μέχρι τη ρίζα. elem find(elem x) { while (x!= A[x]) x = A[x]; return(x); } union(x, y): x και y αντιπρόσωποι διαφορετικών συνόλων Συνένωση δέντρων: ρίζα 1 ου συν. γίνεται γονέας ρίζας 2 ου συν. Ενημέρωση μεγέθους Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2012) Λεξικό, Union - Find 10

Ένωση α 4 ε 3 β γ ζ η δ α 7 uniontree(elem x, elem y) { if (x == y) return; A[y] = x; A[x].size += A[y].size; } β γ ε δ ζ η Λεξικό, Union - Find 11

Απόδοση Χρόνος χ.π. για m finds και n unions: O(mn+ n) Union : Ο(1) χρόνος. Find : Ο(ύψος δέντρου) Χειρότερη περίπτωση: ύψος = n 1 union(n-1, n), union(n-2, n-1), union(n-3, n-2), union(n-4, n-3),, union(3, 2), union(1, 2). Απλή δομή, εύκολη υλοποίηση, αλλά ακριβό find! Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2012) Λεξικό, Union - Find 12

Βεβαρυμένη Ένωση «εύτερο» σύνολο αυτό με τα λιγότερα στοιχεία. Λογαριθμικό ύψος δέντρου : Ο(log n). Βεβαρυμένη ένωση: δέντρο ύψους h έχει 2 h στοιχεία. Απόδειξη με επαγωγή: Ισχύει για h = 0 (δέντρο ενός στοιχείου). Ένωση δέντρων x και y με ύψη h x, h y, και στοιχεία s x s y Επαγωγικά, υποθέτουμε s 2 h (για x και y) Ύψος ένωσης = h x : στοιχεία ένωσης 2 ύψος Ύψος ένωσης = h y + 1 : στοιχεία ένωσης 2 s y 2 ύψος Χρόνος χ.π. για m finds και n unions: O(m log n + n) Απλή υλοποίηση και αποδεκτή απόδοση. Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2012) Λεξικό, Union - Find 13

Σύμπτυξη Μονοπατιών Find ακριβό γιατί στοιχεία μακριά από ρίζα. Σύμπτυξη μονοπατιού όταν find(x): Όλοι οι πρόγονοι του x (και το x) γίνονται παιδιά ρίζας. έντρο «κονταίνει» (όχι επιβάρυνση ασυμπτωτικού χρόνου). Στο μέλλον, θα βρίσκουμε σύνολο των στοιχείων γρήγορα. Λεξικό, Union - Find 14

Σύμπτυξη Μονοπατιών elem findtreepathcompression(elem x) { if (x!= A[x]) A[x] = findtreepathcompression(a[x]); return(a[x]); } Ανεβαίνουμε μέχρι ρίζα. Επιστρέφοντας μέχρι x, όλοι οι δείκτες γονεων τίθενται να δείχνουν στη ρίζα. Λεξικό, Union - Find 15

Απόδοση έντρα, βεβαρυμένη ένωση, και σύμπτυξη μονοπατιών. Χρόνος χ.π. για m n finds και n unions: O(m α(n, m)) α(n, m): αντίστροφη συνάρτηση Ackermann. Μεγαλώνει εξαιρετικά αργά! Στην πράξη, μπορεί να θεωρηθεί σταθερά. Απλή δομή, εύκολη υλοποίηση, και ουσιαστικά γραμμικός χρόνος! Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2012) Λεξικό, Union - Find 16