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

Slides:



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

Δένδρα van Emde Boas TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Μελετάμε την περίπτωση όπου αποθηκεύουμε.
Συλλογές, Στοίβες και Ουρές Σε πολλές εφαρμογές μας αρκεί η αναπαράσταση ενός δυναμικού συνόλου με μια δομή δεδομένων η οποία δεν υποστηρίζει την αναζήτηση.
Δυναμικοί πίνακες Πολλές δομές δεδομένων υλοποιούνται με χρήση πινάκων
ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι
ΣΤΟΙΧΕΙΑ ΨΕΥΔΟΚΩΔΙΚΑ ΒΑΣΙΚΕΣ ΔΟΜΕΣ ΒΑΣΙΚΟΙ ΑΛΓΟΡΙΘΜΟΙ ΠΙΝΑΚΩΝ
Διακριτά Μαθηματικά ΙI Δέντρα
Εισαγωγή στην επιστήμη των υπολογιστών
TEMPLATES STANDARD TEMPLATE LIBRARY ΟΝΤΟΚΕΝΤΡΙΚΟΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ C Evangelos Theodoridis.
Κατακερματισμός Βάσεις Δεδομένων Ευαγγελία Πιτουρά.
Βάσεις Δεδομένων Ευαγγελία Πιτουρά1 Δυναμικός Κατακερματισμός.
Εισαγωγικές Έννοιες Διδάσκοντες: Σ. Ζάχος, Δ. Φωτάκης Επιμέλεια διαφανειών: Δ. Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό Μετσόβιο.
Επιλογή Διδάσκοντες: Σ. Ζάχος, Δ. Φωτάκης Επιμέλεια διαφανειών: Δ. Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό Μετσόβιο Πολυτεχνείο.
ΣΧΕΣΙΑΚΟ ΜΟΝΤΕΛΟ ΜΑΘΗΜΑ 3.
Κοντινότεροι Κοινοί Πρόγονοι α βγ θ δεζ η π ν ι κλμ ρσ τ κκπ(λ,ι)=α, κκπ(τ,σ)=ν, κκπ(λ,π)=η κκπ(π,σ)=γ, κκπ(ξ,ο)=κ ξο κκπ(ι,ξ)=β, κκπ(τ,θ)=θ, κκπ(ο,μ)=α.
Διαίρει-και-Βασίλευε
Δυναμικός Προγραμματισμός
Δυναμική Διατήρηση Γραμμικής Διάταξης Διατηρεί μια γραμμική διάταξη δυναμικά μεταβαλλόμενης συλλογής στοιχείων. Υποστηρίζει τις λειτουργίες: Έλεγχος της.
Δομές Αναζήτησης TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Χειριζόμαστε ένα σύνολο στοιχείων όπου το κάθε.
Αλγόριθμοι και Πολυπλοκότητα
Γράφοι: Προβλήματα και Αλγόριθμοι
Προσεγγιστικοί Αλγόριθμοι για NP-Δύσκολα Προβλήματα
Ουρά Προτεραιότητας: Heap
Lists– Λίστες 1. Αυτό-αναφορικές δομές Τα μέλη μίας δομής μπορεί να είναι οποιουδήποτε τύπου, ακόμα και δείκτες σε δομές του ίδιου τύπου. Χρησιμοποιώντας.
Δομές Δεδομένων.
Συντομότερες Διαδρομές
Διδάσκοντες: Σ. Ζάχος, Δ. Φωτάκης
TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Ουρά Προτεραιότητας (priority queue) Δομή δεδομένων που υποστηρίζει.
TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Ουρά Προτεραιότητας (priority queue) Δομή δεδομένων που υποστηρίζει.
Δομές Δεδομένων. Επιλογή δομής δεδομένων Κριτήρια: – Μέγεθος του προβλήματος – Πως θα χρησιμοποιηθεί Ενέργειες που καθορίζουν το κόστος: – Lookup: αναζήτηση/έλεγχος.
ΕΠΛ 223 Θεωρία και Πρακτική Μεταγλωττιστών7-1 Πίνακας Συμβόλων Πίνακας συμβόλων: δομή δεδομένων που χρησιμοποιείται για την αποθήκευση διαφόρων πληροφοριών.
Ειδικά Θέματα Αλγορίθμων και Δομών Δεδομένων
Εξόρυξη Δεδομένων και Αλγόριθμοι Μάθησης. K-means k-windows k-means: 2 φάσεις 1. Μια διαμέριση των στοιχείων σε k clusters 2. Η ποιότητα της διαμέρισης.
TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Ουρά Προτεραιότητας (priority queue) Δομή δεδομένων που υποστηρίζει.
Ελάχιστο Συνδετικό Δέντρο
Δομές Δεδομένων - Ισοζυγισμένα Δυαδικά Δένδρα (balanced binary trees)
Δομές Αναζήτησης TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Θέλουμε να υποστηρίξουμε δύο βασικές λειτουργίες:
ΘΕΜΑΤΙΚΗ ΕΝΟΤΗΤΑ 2: ΘΕΜΑΤΑ ΘΕΩΡΗΤΙΚΗΣ ΕΠΙΣΤΗΜΗΣ Η/Υ
Υπολογιστική Πολυπλοκότητα Διδάσκοντες: Σ. Ζάχος, Δ. Φωτάκης Επιμέλεια διαφανειών: Δ. Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό.
Θεωρία Γράφων Θεμελιώσεις-Αλγόριθμοι-Εφαρμογές
Αναζήτηση Κατά Βάθος Διδάσκοντες: Σ. Ζάχος, Δ. Φωτάκης Επιμέλεια διαφανειών: Δ. Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό Μετσόβιο.
Quicksort Διδάσκοντες: Σ. Ζάχος, Δ. Φωτάκης Επιμέλεια διαφανειών: Δ. Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό Μετσόβιο Πολυτεχνείο.
Advanced Data Indexing (Προηγμένη ευρετηρίαση δεδομένων) Κατακερματισμός – Hashing (1 ο Μέρος)
Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1 Εισαγωγή στην Επεξεργασία Ερωτήσεων.
ΕΠΛ 231 – Δομές Δεδομένων και Αλγόριθμοι
ΑΝΑΠΤΥΞΗ ΕΦΑΡΜΟΓΩΝ ΣΕ ΠΡΟΓΡΑΜΜΑΤΙΣΤΙΚΟ ΠΕΡΙΒΑΛΛΟΝ §3.7 ΤΑΞΙΝΟΜΗΣΗ
Θεωρία Βασικών Δομών Δεδομένων Διδάσκοντες:Μακρής Χρήστος, Τσακαλίδης Αθανάσιος
Μέγιστη ροή TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A AA A A Συνάρτηση χωρητικότητας Κατευθυνόμενο γράφημα.
Ασυμπτωτικός Συμβολισμός
Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1 Επεξεργασία Ερωτήσεων.
Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1 Ευρετήρια.
Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1 Ευρετήρια.
Συνδετικότητα γραφήματος (graph connectivity). α β Υπάρχει μονοπάτι μεταξύ α και β; Παραδείγματα: υπολογιστές ενός δικτύου ιστοσελίδες ισοδύναμες μεταβλητές.
ΔΥΑΔΙΚΗ ΑΝΑΖΗΤΗΣΗ & ΤΑΞΙΝΟΜΗΣΗ ΜΕ ΣΥΓΧΩΝΕΥΣΗ. Δυαδική αναζήτηση (Binary search) ΔΕΔΟΜΕΝΟ: ένα μεγάλο αρχείο που περιέχει τιμές z [0,1,…,n-1] ταξινομημένες.
Γράφημα Συνδυαστικό αντικείμενο που αποτελείται από 2 σύνολα:
Ευρετήρια Βάσεις Δεδομένων Ευαγγελία Πιτουρά.
Δυναμικός Κατακερματισμός
Μέγιστη ροή Κατευθυνόμενο γράφημα 12 Συνάρτηση χωρητικότητας
Κάθε ένα από τα αντικείμενα λέγεται στοιχείο του πίνακα.
Σειριακή ή Γραμμική Αναζήτηση 1.Μοναδικό Κλειδί (key)
Ανάπτυξη Εφαρμογών σε Προγραμματιστικό Περιβάλλον ΑΕΠΠ
Ουρά Προτεραιότητας (priority queue)
Ανάπτυξη Εφαρμογών σε Προγραμματιστικό Περιβάλλον ΑΕΠΠ
Δομές Αναζήτησης Χειριζόμαστε ένα σύνολο στοιχείων όπου το κάθε στοιχείο έχει ένα κλειδί από ολικά διατεταγμένο σύνολο Θέλουμε να υποστηρίξουμε δύο.
Union - Find 30 Μαρτίου 2017.
Εξωτερική Αναζήτηση Ιεραρχία Μνήμης Υπολογιστή Εξωτερική Μνήμη
Διαχρονικές Δομές Δεδομένων
Δυναμικός Κατακερματισμός
Στοιχεία Χωρικής Πολυπλοκότητας
Μεταγράφημα παρουσίασης:

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

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

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

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

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

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

Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2011)Λεξικό, Union - Find 7 Πρόβλημα 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 ενώσεων.

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

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

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

Λεξικό, Union - Find 11 Ένωση unionTree(elem x, elem y) { if (x == y) return; A[y] = x; A[x].size += A[y].size; }

Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2011)Λεξικό, Union - Find 12 Απόδοση  Χρόνος χ.π. για m finds και n unions: O(m n + 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!

Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2011)Λεξικό, Union - Find 13 Βεβαρυμένη Ένωση  «Δεύτερο» σύνολο αυτό με τα λιγότερα στοιχεία. Λογαριθμικό ύψος δέντρου : Ο(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) Απλή υλοποίηση και αποδεκτή απόδοση.

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

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

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