Δοµές Δεδοµένων. 13η Διάλεξη Πίνακες Συµβόλων. Ε. Μαρκάκης

Σχετικά έγγραφα
ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Πίνακες Συµβόλων Κεφάλαιο 12 ( ) Ε. Μαρκάκης Επίκουρος Καθηγητής

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

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Εξωτερική Αναζήτηση και Β-δέντρα Κεφάλαιο 16. Ε. Μαρκάκης Επίκουρος Καθηγητής

Δοµές Δεδοµένων. 16η Διάλεξη Κατακερµατισµός. Ε. Μαρκάκης

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Δέντρα Δυαδικής Αναζήτησης Κεφάλαιο 12 ( ) Ε. Μαρκάκης Επίκουρος Καθηγητής

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

Λίστες παράλειψης (skip lists)

Δοµές Δεδοµένων. 8η Διάλεξη: Ταξινόµηση. Ε. Μαρκάκης

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

Δοµές Δεδοµένων. 12η Διάλεξη Διάσχιση Δέντρων και Ουρές Προτεραιότητας. Ε. Μαρκάκης

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

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

Δοµές Δεδοµένων. 6η Διάλεξη Αναδροµικές Εξισώσεις και Αφηρηµένοι Τύποι Δεδοµένων. Ε. Μαρκάκης

Δοµές Δεδοµένων. 9η Διάλεξη Ταξινόµηση - Στοιχειώδεις µέθοδοι. Ε. Μαρκάκης

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

Συλλογές, Στοίβες και Ουρές

Δοµές Δεδοµένων. 4η Διάλεξη Στοιχειώδεις Δοµές Δεδοµένων: Πίνακες και Λίστες. Ε. Μαρκάκης

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

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

Δοµές Δεδοµένων. 7η Διάλεξη Αφηρηµένοι Τύποι Δεδοµένων. Ε. Μαρκάκης

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

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Στοιχειώδεις Δοµές Δεδοµένων Λίστες Κεφάλαιο 3 (3.3, 3.4, 3.7) Ε. Μαρκάκης Επικ. Καθηγητής

Στοιχειώδεις Δομές Δεδομένων

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Στοιχειώδεις Δοµές Δεδοµένων Λίστες Κεφάλαιο 3 (3.3, 3.4, 3.7) Ε. Μαρκάκης Επικ. Καθηγητής

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Ταξινόµηση - Στοιχειώδεις µέθοδοι Κεφάλαιο 6. Ε. Μαρκάκης Επίκουρος Καθηγητής

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

Βασικές Έννοιες Δοµών Δεδοµένων

Δοµές Δεδοµένων. 2η Διάλεξη Αλγόριθµοι Ένωσης-Εύρεσης (Union-Find) Ε. Μαρκάκης. Βασίζεται στις διαφάνειες των R. Sedgewick K.

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

Διάλεξη 08: Λίστες ΙΙ Κυκλικές Λίστες

Δοµές Δεδοµένων. 5η Διάλεξη Λίστες και αρχές ανάλυσης αλγορίθµων. Ε. Μαρκάκης

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

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

Γράφημα. Συνδυαστικό αντικείμενο που αποτελείται από 2 σύνολα: Σύνολο κορυφών (vertex set) Σύνολο ακμών (edge set) 4 5 πλήθος κορυφών πλήθος ακμών

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

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

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

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

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

Δοµές Δεδοµένων. 10η Διάλεξη Ταξινόµηση. E. Μαρκάκης

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

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

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

Διάλεξη 07: Λίστες Ι Υλοποίηση & Εφαρμογές

Απλές Δοµές Δεδοµένων Στην ενότητα αυτή θα γνωρίσουµε ορισµένες απλές Δοµές Δεδοµένων και θα τις χρησιµοποιήσουµε για την αποδοτική επίλυση του προβλή

Τύποι Δεδομένων και Απλές Δομές Δεδομένων. Παύλος Εφραιμίδης V1.0 ( )

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

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

Διάλεξη 08: Λίστες ΙΙ Κυκλικές Λίστες

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Ταξινόµηση Mergesort Κεφάλαιο 8. Ε. Μαρκάκης Επίκουρος Καθηγητής

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Αρχές Ανάλυσης Αλγορίθµων Κεφάλαιο 2. Ε. Μαρκάκης Επικ. Καθηγητής

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Στοιχειώδεις Δοµές Δεδοµένων Δοµικά Στοιχεία και Πίνακες Κεφάλαιο 3 (3.1 και 3.2) Ε. Μαρκάκης Επικ. Καθηγητής

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Αλγόριθµοι Ένωσης-Εύρεσης (Union-Find) Κεφάλαιο 1. Ε. Μαρκάκης Επικ. Καθηγητής

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

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

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

διεύθυνση πρώτου στοιχείου διεύθυνση i-οστού στοιχείου T t[n]; &t[0] είναι t &t[i] είναι t + i*sizeof(t)

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

Σύνοψη Προηγούμενου (1/2) Στοίβες, Ουρές, Ουρές Προτεραιότητας. Σύνοψη Προηγούμενου (2/2) Σημερινό Μάθημα. Πίνακες. Εισαγωγή, σε χρόνο O(1).

Δομές Δεδομένων & Ανάλυση Αλγορίθμων. 3ο Εξάμηνο. Ουρά (Queue) Υλοποίηση της με τη βοήθεια πίνακα.

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

Διάλεξη 06: Συνδεδεμένες Λίστες & Εφαρμογές Στοιβών και Ουρών

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

Δοµές Δεδοµένων. 3η Διάλεξη Στοιχειώδεις Δοµές Δεδοµένων: Πίνακες. Ε. Μαρκάκης

Αντικειµενοστρεφής Προγραµµατισµός

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

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

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Ταξινόµηση Quicksort Κεφάλαιο 7. Ε. Μαρκάκης Επίκουρος Καθηγητής

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

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

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

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

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

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

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

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

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

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

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

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

Δομές Δεδομένων. Δημήτρης Μιχαήλ. Υλοποίηση Δυαδικού Σωρού σε γλώσσα Java. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο

Tύπος δεδοµένων (data type) µιας µεταβλητής (σε µια γλώσσα προγραµµατισµού) είναι το σύνολο των τιµών που µπορεί να πάρει η µεταβλητή.

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

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

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Αναφορές

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

Διάλεξη 21η: Απλά Συνδεδεμένες Λίστες

2.1. Εντολές Σχόλια Τύποι Δεδομένων

1 ΕΙΣΑΓΩΓΗ. Πρωταρχικοί Τύποι

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

#include <stdlib.h> Α. [-128,127] Β. [-127,128] Γ. [-128,128]

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

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

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

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

Διάλεξη 05: Αφηρημένοι Τύποι Δεδομένων

Συγκρίσιμα Αντικείμενα (comparable)

Οικονοµικό Πανεπιστήµιο Αθηνών. Τµήµα Πληροφορικής. Φθινοπωρινό Εξάµηνο Δοµές Δεδοµένων - Εργασία 2. Διδάσκων: E. Μαρκάκης

ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 5. Αφηρημένοι Τύποι Δεδομένων / Στοίβες και Ουρές

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

Transcript:

Δοµές Δεδοµένων 13η Διάλεξη Πίνακες Συµβόλων Ε. Μαρκάκης

Ο αλγόριθµος heapsort Παράδειγµα ταξινόµησης µε σωρό Δηµιουργία σωρού (σε µορφή δέντρου) Τα στοιχεία ταξινοµούνται µερικώς Ταξινόµηση µε βάση το σωρό (σε µορφή πίνακα) Ουσιαστικά ταξινόµηση µε επιλογή Επιταχύνεται όµως η επιλογή! Δοµές Δεδοµένων 13-2

Ο αλγόριθµος heapsort Χρήση σωρού για επιλογή Εντοπισµός των k µεγαλύτερων από τα N στοιχεία ή απλώς του k-οστού µεγαλύτερου Η ταξινόµηση λύνει το πρόβληµα σε χρόνο NlοgN Ο σωρός λύνει το πρόβληµα σε γραµµικό χρόνο για µικρό k 1η µέθοδος (προφανής) Κατασκευάζουµε το σωρό σε χρόνο Ο(N) Αφαιρούµε k στοιχεία σε χρόνο 2klοgN 2η µέθοδος (όχι τόσο προφανής) Κατασκευάζουµε έναν ανάποδο σωρό µε k στοιχεία Η εξαγωγή αφαιρεί το µικρότερο στοιχείο Κάνουµε N-k εισαγωγές ακολουθούµενες από εξαγωγές του ελάχιστου Κάθε φορά βγάζουµε το µικρότερο από k+1 στοιχεία Συνολικό κόστος 2k + 2(N-k)lοgk Δοµές Δεδοµένων 13-3

Μέρος 4 Αναζήτηση Δοµές Δεδοµένων 13-4

Περίληψη Πίνακες συµβόλων Διεπαφή πίνακα συµβόλων Αναζήτηση µε αριθµοδείκτη Ακολουθιακή αναζήτηση Δυαδική αναζήτηση Δοµές Δεδοµένων 13-5

Πίνακες συµβόλων Αναζήτηση και ανάκτηση πληροφοριών Από τα πιο στοιχειώδη προβλήµατα στην πληροφορική Απαιτήσεις Δοµές δεδοµένων για την αποθήκευση των στοιχείων Ταχύτητα ανάκτησης (Google, τράπεζες, δηµόσιες υπηρεσίες,...) Ορισµός πίνακα συµβόλων (symbol table) Είναι οποιαδήποτε δοµή δεδοµένων που περιέχει στοιχεία µε κλειδιά και υποστηρίζει τις εξής λειτουργίες: Εισαγωγή νέου στοιχείου µε κάποιο κλειδί Επιστροφή στοιχείου µε κάποιο δοσµένο κλειδί (αναζήτηση) Ονοµάζεται και λεξικό (dictionary) Τα έντυπα λεξικά είναι πάντα ταξινοµηµένα Τα ηλεκτρονικά λεξικά δεν είναι απαραίτητα ταξινοµηµένα Δοµές Δεδοµένων 13-6

Διεπαφή πίνακα συµβόλων Πληθώρα εφαρµογών Λεξικά, ευρετήρια, µεταγλωττιστές, DNS, δροµολόγηση Διάφορες υλοποιήσεις Ταξινοµηµένοι ή αταξινόµητοι πίνακες ή λίστες Δέντρα αναζήτησης, δυαδικά ή µε µεγαλύτερο βαθµό Πίνακες κατακερµατισµού Άλλες υποστηριζόµενες λειτουργίες Αφαίρεση, επιλογή k-οστού στοιχείου, ταξινόµηση, ένωση (προαιρετικά) Δοµές Δεδοµένων 13-7

Διεπαφή πίνακα συµβόλων Γενική µορφή στοιχείων και κλειδιών Κάνει τις υλοποιήσεις πιο γενικές Ένας πίνακας συµβόλων περιέχει στοιχεία (π.χ. αντικείµενα µε όλες τις πληροφορίες ενός πελάτη µιας τράπεζας) Κάθε στοιχείο περιέχει ένα κλειδί (που είναι συγκρίσιµο) µε πρόσβαση µεσω της µεθόδου key() interface ITEM { KEY key(); /*μέθοδος πρόσβασης στο κλειδί */ } interface KEY { boolean less(key v); boolean equals(key v); } Εναλλακτικά αντί για less και equals, µπορούµε να έχουµε τριµερή σύγκριση (µικρότερο, ίσο, µεγαλύτερο) int compareto(key v); Επιστρέφει 1 αν το κλειδί > v, 0 αν είναι ίσα και -1 διαφορετικά Δοµές Δεδοµένων 13-8

Διεπαφή πίνακα συµβόλων Διεπαφή τάξης στοιχείων / κλειδιών Οι πίνακες συµβόλων χρησιµοποιούν µόνο αυτή τη διεπαφή Δηµιουργία στοιχείων / κλειδιών µε δύο τρόπους class myitem implements ITEM { public KEY key() void read() void rand() //µπορούµε να προσθέσουµε και άλλες λειτουργίες εδώ public String tostring() } class mykey implements KEY { public boolean less(mykey) public boolean equals(mykey) void read() void rand() public String tostring() } Δοµές Δεδοµένων 13-9

Διεπαφή πίνακα συµβόλων Παράδειγµα υλοποίησης κλειδιών Τα κλειδιά είναι ακέραιες τιµές class mykey implements KEY { private int val; // η τιμή του κλειδιού public boolean less(key w) { return val < ((mykey) w).val; } public boolean equals(key w) { return val == ((mykey) w).val; } public void read() { val = In.getInt(); } public void rand() { τιμή val = (int) (M * Math.random()); }//Μ=μέγιστη public String tostring() { return val + ""; } } Δοµές Δεδοµένων 13-10

Διεπαφή πίνακα συµβόλων Παράδειγµα υλοποίησης στοιχείων Στοιχεία µε έναν πραγµατικό αριθµό (π.χ. υπόλοιπο λογαριασµού) Τα κλειδιά είναι ακέραιες τιµές (υλοποιούνται χωριστά) (π.χ. ΑΦΜ) class myitem implements ITEM { private mykey bankkey; private float balance; myitem() { bankkey = new mykey(); } public KEY key() { return bankkey; } void read() { bankkey.read(); balance = In.getFloat(); } void rand() { bankkey.rand(); balance = (float) Math.random(); } public String tostring() { return "(" + key() + " " + balance + ")"; } } Δοµές Δεδοµένων 13-11

Διεπαφή πίνακα συµβόλων Παράδειγµα απλούστερης υλοποίησης στοιχείων Όταν τα κλειδιά είναι στοιχειώδεις τύποι δεδοµένων, µπορούµε να αποφύγουµε την υλοποίηση της KEY Μικρότερο κόστος αλλά και µικρότερη ευελιξία class intkeyitem { private int val; private float info; public int key() { return val; } void read() { val = In.getInt(); info = In.getFloat(); } void rand() { val = (int) (M * Math.random()); info = (float) Math.random(); } public String tostring() { return "(" + key() + " " + info + ")"; } } Δοµές Δεδοµένων 13-12

Διεπαφή πίνακα συµβόλων Διεπαφή του ίδιου του πίνακα συµβόλων Χρησιµοποιούµε ένα µέγιστο µέγεθος στον κατασκευαστή Βολικό στις υλοποιήσεις µε πίνακα class ST { ST(int) int count() //μετρά το μέγεθος του πίνακα void insert(item) ITEM search(key) void remove(key) ITEM select(int) //επιστροφή k-οστού μικρότερου public String tostring() } Δοµές Δεδοµένων 13-13

Διεπαφή πίνακα συµβόλων Χειρισµός διπλών κλειδιών Η διεπαφή δεν διευκρινίζει τι γίνεται µε τα διπλά κλειδιά Σε ορισµένες περιπτώσεις δεν επιτρέπονται διπλά κλειδιά Τι γίνεται όµως αν επιτρέπονται; Πρώτη προσέγγιση: µία καταχώρηση ανά κλειδί Χρήση λίστας για τα στοιχεία µε το ίδιο κλειδί Βολική όταν θέλουµε να βρίσκουµε τα στοιχεία µε ίδιο κλειδί Δεύτερη προσέγγιση: πολλές καταχωρήσεις ανά κλειδί Επιστρέφουµε οποιαδήποτε από αυτές στην αναζήτηση Μπορεί η δοµή να χρειάζεται τροποποίηση Επιλογή υλοποίησης Κάθε υλοποίηση βελτιστοποιεί συγκεκριµένες πράξεις Δοµές Δεδοµένων 13-14

Διεπαφή πίνακα συµβόλων Παράδειγµα πελάτη πίνακα συµβόλων Παραλείπει τα διπλά στοιχεία από την είσοδο class DeDup { public static void main(string[] args) { int i, N = Integer.parseInt(args[0]), sw = Integer.parseInt(args[1]); ST st = new ST(N); for (i = 0; i < N; i++) { myitem v = new myitem(); if (sw == 1) v.rand(); else v.read(); if (st.search(v.key()) == null) { st.insert(v); Out.println(v + ""); } } Out.print(N + " keys, "); Out.println(N-st.count() + " dups"); } } Δοµές Δεδοµένων 13-15

Αναζήτηση µε αριθµοδείκτη Κατάλληλη όταν τα κλειδιά είναι µικροί ακέραιοι Χρήση ενός πίνακα µε αριθµοδείκτες τα κλειδιά Οι θέσεις του πίνακα δείχνουν σε στοιχεία ή σε null Εισαγωγή: αποθήκευση στοιχείου µε κλειδί i στη θέση st[i] Αναζήτηση κλειδιού i: επιστροφή θέσης i Αφαίρεση κλειδιού i: τοποθέτηση null στη θέση st[i] Καταµέτρηση και εκτύπωση µε σάρωση του πίνακα Σε κάποιες περιπτώσεις µπορούµε να έχουµε πίνακα από bits bit k = 0: δεν έχει εισαχθεί το κλειδί k, διαφορετικά bit k = 1 Δοµές Δεδοµένων 13-16

Αναζήτηση µε αριθµοδείκτη Παράδειγµα υλοποίησης (µέσω της intkeyitem) class ST { private intkeyitem[] st; ST(int M) { st = new intkeyitem[m]; } int count() { int N = 0; for (int i = 0; i < st.length; i++) if (st[i]!= null) N++; return N; } void insert(intkeyitem x) { st[x.key()] = x; } void remove(int key) { st[key] = null; } intkeyitem search(int key) { return st[key]; } intkeyitem select(int k) { for (int i = 0; i < st.length; i++) if (st[i]!= null && k-- == 0) return st[i]; return null; } } Δοµές Δεδοµένων 13-17

Αναζήτηση µε αριθµοδείκτη Καταµέτρηση: Η υλοποίηση εφαρµόζει ράθυµη (lazy) προσέγγιση Θα µπορούσαµε να διατηρούµε έναν µετρητή στοιχείων Κόστος σε κάθε λειτουργία αντί όποτε ζητηθεί καταµέτρηση Ανάλυση κόστους Έστω ότι τα κλειδιά είναι N θετικοί ακέραιοι < M Εισαγωγή, αναζήτηση και αφαίρεση: σταθερό κόστος ταξινόµηση: M βήµατα Υπενθύµιση: ταξινόµηση µε αριθµοδείκτη είναι Ο(Μ) όταν τα κλειδιά είναι όλα ακέραιοι Μ Δοµές Δεδοµένων 13-18

Ακολουθιακή αναζήτηση Αν δεν µπορούµε να χρησιµοποιήσουµε τα κλειδια ως αριθµοδείκτες: Χρήση ταξινοµηµένου πίνακα Η εισαγωγή απαιτεί µετακίνηση στοιχείων για να µπει στη σωστή θέση το στοιχείο Η αναζήτηση απαιτεί σάρωση στοιχείων Σταµατάµε όταν βρούµε ίσο ή µεγαλύτερο κλειδί Απλή υλοποίηση της επιλογής Αφαίρεση ανάλογη µε την εισαγωγή (πρέπει ο πίνακας να παραµείνει ταξινοµηµένος) Δοµές Δεδοµένων 13-19

Ακολουθιακή αναζήτηση Αναπαράσταση στοιχείων / κλειδιών Παράλληλοι πίνακες Τάξη στοιχείων µε δύο πεδία Τάξη στοιχείων και τάξη κλειδιών (για στοιχειώδεις τύπους υλοποίηση ITEM και ΚΕΥ κοστίζει πολύ) 2 δείκτες για την προσπέλαση του κλειδιού Αυξανόµενη γενικότητα Αυξανόµενο κόστος Δοµές Δεδοµένων 13-20

Ακολουθιακή αναζήτηση class ST { private ITEM[] st; private int N = 0; ST(int maxn) { st = new ITEM[maxN]; } void insert(item x) { int i = N++; KEY v = x.key(); while (i > 0 && less(v, st[i-1].key())) { st[i] = st[i-1]; i--; } st[i] = x; } ITEM search(key key) { int i = 0; for ( ; i < N; i++) if (!less(st[i].key(), key)) break; if (i == N) return null; if (equals(key, st[i].key())) return st[i]; return null; } } ITEM select(int k) {return st[k];} int count() {return N;} Δοµές Δεδοµένων 13-21

Ακολουθιακή αναζήτηση Χρήση αταξινόµητου πίνακα Πιο γρήγορη εισαγωγή (στο τέλος) Πιο αργή αναζήτηση (πιθανή σάρωση όλου του πίνακα) Πιο γρήγορη αφαίρεση (µε ανταλλαγή µε το τελευταίο στοιχείο), πιο αργή επιλογή Χρήση συνδεδεµένης λίστας Ταξινοµηµένη ή αταξινόµητη Ανάλογα πλεονεκτήµατα και µειονεκτήµατα µε τους πίνακες Η λίστα διευκολύνει την ταξινοµηµένη εισαγωγή Κόστος (χρόνος και χώρος) διαχείρισης δεικτών Ταξινοµηµένη ή αταξινόµητη δοµή; Εξαρτάται από την εφαρµογή Αν είναι πιο συχνή η εισαγωγή, τότε αταξινόµητη Αν είναι πιο συχνή η αναζήτηση, τότε ταξινοµηµένη Δοµές Δεδοµένων 13-22

Ακολουθιακή αναζήτηση Υλοποίηση µε αταξινόµητη λίστα class ST { private class Node { ITEM item; Node next; Node(ITEM x, Node t) { item = x; next = t; } } private Node head; private int N; ST(int maxn) { head = null; N = 0; } int count() { return N; } void insert(item x) { head = new Node(x, head); N++; } private ITEM searchr(node t, KEY key) { if (t == null) return null; if (equals(t.item.key(), key)) return t.item; return searchr(t.next, key); } ITEM search(key key) {return searchr(head, key); }} Δοµές Δεδοµένων 13-23

Ακολουθιακή αναζήτηση Ανάλυση κόστους Διακρίνουµε επιτυχηµένες και αποτυχηµένες αναζητήσεις Γενική ιδιότητα: N/2 συγκρίσεις για επιτυχή αναζήτηση κατά µέσο όρο Λίστα ή πίνακας, ταξινοµηµένα ή αταξινόµητα Μη ταξινοµηµένα στοιχεία Σταθερό κόστος εισαγωγής N συγκρίσεις για αποτυχηµένη αναζήτηση Ισχύει για λίστα ή πίνακα Ταξινοµηµένα στοιχεία Κατά µέσο όρο N/2 συγκρίσεις για εισαγωγή και επιτυχή ή ανεπιτυχή αναζήτηση Ισχύει για λίστα ή πίνακα Δοµές Δεδοµένων 13-24

Δυαδική αναζήτηση Τακτική αναζήτησης διαίρει και βασίλευε Διαιρούµε τον πίνακα συµβόλων σε δύο ίσα τµήµατα Πιθανόν να διαφέρουν κατά 1 στοιχείο Συνεχίζουµε στο τµήµα που περιέχει το ζητούµενο κλειδί Χρησιµοποιεί ταξινοµηµένο πίνακα private ITEM searchr(int l, int r, KEY v) { if (l > r) return null; int m = (l+r)/2; if (equals(v, st[m].key())) return st[m]; if (less(v, st[m].key())) return searchr(l, m-1, v); else return searchr(m+1, r, v); } ITEM search(key v) { return searchr(0, N-1, v); } Δοµές Δεδοµένων 13-25

Δυαδική αναζήτηση Απόδοση δυαδικής αναζήτησης Το πολύ floor(lοgn)+1 συγκρίσεις, επιτυχείς ή µη αναζητήσεις Πρόβληµα: διατήρηση του πίνακα ταξινοµηµένου Αν τα στοιχεία εισάγονται δυναµικά έχουµε πρόβληµα Χρειάζεται συνεχής µετακίνηση των στοιχείων του πίνακα Η συνδεδεµένη λίστα εµποδίζει την άµεση προσπέλαση Δοµές Δεδοµένων 13-26

Δυαδική αναζήτηση Προκαθορισµένη ακολουθία συγκρίσεων Εξαρτάται µόνο από το µέγεθος του αρχείου Ακολουθούµε µοναδική διαδροµή στο δένδρο Χειρισµός διπλών κλειδιών Η ταξινόµηση τοποθετεί τα κλειδιά σε συνεχόµενες θέσεις Η αναζήτηση οδηγεί σε κάποια από αυτές τις θέσεις Απλές προσθήκες για σάρωση των γειτονικών θέσεων Επιτάχυνση µε παρεµβολή Υπολογίζουµε πού περίπου πρέπει να βρίσκεται το κλειδί Υποθέτουµε οµοιόµορφη κατανοµή κλειδιών Διασπάµε τον πίνακα εκεί και όχι στο µέσο m = l + (v a[l].key()) * (r l) / (a[r].key() a[l].key()) Δοµές Δεδοµένων 13-27