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

Μέγεθος: px
Εμφάνιση ξεκινά από τη σελίδα:

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

Transcript

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

2 Περίληψη Ταξινόµηση: οι κανόνες του παιχνιδιού Ταξινόµηση µε εισαγωγή Γενικές Υλοποιήσεις Bubble Sort Selection Sort Insertion Sort Χαρακτηριστικά επιδόσεων Shellsort Ταξινόµηση συνδεδεµένων λιστών Ταξινόµηση µε αριθµοδείκτη κλειδιού Δοµές Δεδοµένων 07-2

3 Οι κανόνες του παιχνιδιού Στόχος ταξινόµησης Είσοδος: Δίνεται ένα σύνολο Ν στοιχείων/αντικειµένων Υλοποίηση των συνόλων µε πίνακες ή λίστες Κάθε στοιχείο περιλαµβάνει ένα κλειδί Έξοδος: Αναδιάταξη των στοιχείων σύµφωνα µε τα κλειδιά Αύξουσα / φθίνουσα, αριθµητική / λεξικογραφική σειρά Είδη ταξινόµησης Εσωτερική ταξινόµηση: τα στοιχεία χωράνε στη µνήµη Εξωτερική ταξινόµηση: τα στοιχεία αποθηκεύονται στο δίσκο, σε βάση, κτλ Προσαρµοστική ταξινόµηση: εξαρτάται από τα στοιχεία Σε εσωτερική ταξινόµηση έχουµε πιο εύκολη πρόσβαση στα στοιχεία Θα ασχοληθούµε κυρίως µε εσωτερική ταξινόµηση Δοµές Δεδοµένων 07-3

4 Οι κανόνες του παιχνιδιού Ταξινόµηση σε πίνακα Κάποιες συµβάσεις/αφαιρέσεις: Θα ασχοληθούµε µε ταξινόµηση σε αύξουσα σειρά sort(): υλοποιεί έναν αλγόριθµο ταξινόµησης, Βασίζεται στις: less(): σύγκριση 2 στοιχείων exch(): αντιµετάθεση 2 στοιχείων compexch(): σύγκριση 2 στοιχείων και αντιµετάθεση αν είναι απαραίτητο αποδεσµεύεται η sort() από τον τύπο δεδοµένων Δοµές Δεδοµένων 07-4

5 Ταξινόµηση µε εισαγωγή (Insertion Sort) H µέθοδος που χρησιµοποιούν οι χαρτοπαίκτες Δείτε εδώ: Ή ψάξτε στο youtube insertion sort Δοµές Δεδοµένων 07-5

6 Ταξινόµηση µε εισαγωγή (Insertion Sort) H ιδέα του αλγορίθµου: Βρόχος στα δεδοµένα εισόδου Έστω ότι ταξινοµούµε τα στοιχεία από 0 ως Ν-1 Στην επανάληψη k: κοιτάµε το στοιχείο a[k] Ο αριστερός υποπίνακας a[0],,a[k-1] είναι ήδη ταξινοµηµένος (από τις προηγούµενες επαναλήψεις) Βρίσκουµε ποια είναι η σωστή θέση για το a[k] (ανάµεσα στις θέσεις 0 ως k) Κανουµε τις απαραίτητες αντιµεταθέσεις Μπορούµε να το υλοποιήσουµε για το εύρος a[p] ως a[r] αντί για a[0] ως a[n-1] Δοµές Δεδοµένων 07-6

7 Ταξινόµηση µε εισαγωγή (Insertion Sort) class ArraySortBasic { //ταξινόµηση των στοιχείων a[p] ως a[r] } static boolean less(double v, double w) { return v < w; } static void exch(double[] a, int i, int j) { double t = a[i]; a[i] = a[j]; a[j] = t; } static void compexch(double[] a, int i, int j) { if (less(a[j], a[i])) exch (a, i, j); } static void sort(double[] a, int p, int r) { //υλοποίηση Insertion Sort for (int i = p+1; i <= r; i++) for (int j = i; j > p; j--) compexch(a, j-1, j); } Δοµές Δεδοµένων 07-7

8 Πολυπλοκότητα Αξιολόγηση αλγορίθµων ταξινόµησης Βασικές λειτουργίες: συγκρίσεις και αντιµεταθέσεις Η σύγκριση απαιτεί ανάγνωση Η µετάθεση απαιτεί ανάγνωση και εγγραφή Οι πιο απλές ταξινοµήσεις είναι συνήθως O(N 2 ) Οι πιο περίπλοκες ταξινοµήσεις είναι O(NlοgN) Υπό προϋποθέσεις, ορισµένες ειδικές ταξινοµήσεις είναι O(N) Πολυπλοκότητα της Insertion Sort Worst case: αν ο πίνακας αρχικά είναι σε φθίνουσα σειρά 1 η επανάληψη: 1 σύγκριση και µετάθεση 2 η επανάληψη: 2 συγκρίσεις και µεταθέσεις... Συνολικά Ν-1 = Ν(Ν-1)/2 = Ο(Ν 2 ) Δοµές Δεδοµένων 07-8

9 Ιδιότητες και επιπλέον είδη ταξινόµησης Ευσταθής και µη ταξινόµηση Πολλές φορές έχουµε στοιχεία µε πολλά κλειδιά Ευσταθής ταξινόµηση: διατηρεί τη σχετική σειρά ως προς το δεύτερο κλειδί Έστω ότι έχουµε ένα αρχείο µε ονόµατα και βαθµούς Αν ταξινοµούµε µε βάση τους βαθµούς, τα ονόµατα που ισοβαθµούν µένουν ταξινοµηµένα σε ευσταθή ταξινόµηση Οι περισσότερες απλές µέθοδοι είναι ευσταθείς Οι περισσότερες από τις πιο πολύπλοκες µεθόδους δεν είναι ευσταθείς Έµµεση ταξινόµηση (indirect sort) Αναδιατάσσουµε τους δείκτες αλλά όχι τα ίδια τα στοιχεία Δοµές Δεδοµένων 07-9

10 Γενικές υλοποιήσεις Σε πολλές περιπτώσεις δεν θα έχετε απλώς έναν πίνακα µε πραγµατικούς ή ακεραίους για ταξινόµηση Στην γραµµατεία κάθε φοιτητής αντιστοιχεί σε ένα αντικείµενο µε Ονοµατεπώνυµο ΑΜ Όνοµα πατέρα/µητέρας Διεύθυνση Τηλέφωνο Κτλ Χρειαζόµαστε πιο γενικές υλοποιήσεις για να µπορούµε να ταξινοµούµε αντικείµενα οποιουδήποτε τύπου ως προς κάποιο πεδίο τους Δοµές Δεδοµένων 07-10

11 Γενικές υλοποιήσεις Αποδέσµευση της ταξινόµησης από τους τύπους δεδοµένων Οι αλγόριθµοι ταξινόµησης δεν εξαρτώνται από τα κλειδιά Αρκεί να µπορούν να τα συγκρίνουν Οι αλγόριθµοι ταξινόµησης δεν εξαρτώνται από τα στοιχεία Αρκεί να µπορούν να τα αντιµεταθέσουν Γενική βιβλιοθήκη ταξινόµησης Ο πελάτης µεταβιβάζει στη sort() έναν πίνακα στοιχείων Η sort() καλεί τις µεθόδους σύγκρισης και αντιµετάθεσης Η βιβλιοθήκη της Java χρησιµοποιεί τη διεπαφή Comparable Aντικείµενα που υλοποιούν το interface Comparable: αρκεί να υλοποιούν τη µέθοδο v.compareto(w) -1 αν v<w, +1 αν v>w, 0 αν v=w Κάθε πίνακας τέτοιων αντικειµένων µπορεί να ταξινοµηθεί Δοµές Δεδοµένων 07-11

12 Γενικές υλοποιήσεις Μια εναλλακτική µορφή της βιβλιοθήκης Αρχικά ορίζουµε έναν γενικό τύπο αντικειµένου ITEM Η διεπαφή ITEM αρκεί να παρέχει τη µέθοδο less() interface ITEM { boolean less(item v); } Στη συνέχεια ορίζουµε τη γενική τάξη ταξινόµησης Sort Η τάξη δεν περιέχει κατάσταση Όλες οι µέθοδοι είναι static Βοηθητική µέθοδος less() Παίρνει ως παράµετρο δύο στοιχεία τύπου ITEM Βοηθητικές µέθοδοι exch() και compexch() Παίρνουν ως παραµέτρους πίνακες µε αντικείµενα ITEM Αντιµεταθέτουν στοιχεία τύπου ITEM Δοµές Δεδοµένων 07-12

13 Γενικές υλοποιήσεις Βοηθητική µέθοδος sort() Καλείται από τους πελάτες µε πίνακα τύπου ITEM και δύο όρια για το εύρος του πίνακα class Sort { static boolean less(item v, ITEM w) { return v.less(w); } static void exch(item[] a, int i, int j) { ITEM t = a[i]; a[i] = a[j]; a[j] = t; } static void compexch(item[] a, int i, int j) { if (less(a[j], a[i])) exch (a, i, j); } static void sort(item[] a, int p, int r) { example(a, p, r); } static void example(item[] a, int p, int r) { for (int i = p+1; i <= r; i++) for (int j = i; j > p; j--) compexch(a, j-1, j); } } Δοµές Δεδοµένων 07-13

14 Γενικές υλοποιήσεις Μπορούµε να έχουµε ΑΤΔ στοιχείων προς ταξινόµηση Και ΑΤΔ πίνακα στοιχείων ΑΤΔ στοιχείων Υλοποιεί τη διεπαφή ITEM Πρέπει να παρέχει υλοποίηση της less() Μπορούµε να προσθέσουµε ανάγνωση, τυχαίο ορισµό, εµφάνιση στοιχείων, κτλ Παράδειγµα: class myitem implements ITEM { public boolean less(item) //υλοποιεί τη σύγκριση void read() //διαβάζει το στοιχείο από την είσοδο void rand() //παράγει ένα τυχαίο στοιχείο public String tostring() // + ό,τι άλλο µπορεί να απαιτείται από την εφαρµογή } Δοµές Δεδοµένων 07-14

15 Γενικές υλοποιήσεις Παράδειγµα 1: τύποι ταξινόµησης ακεραίων Υλοποίηση τάξης myitem Χρησιµοποιεί τις πράξεις των ακεραίων Προσοχή στις µετατροπές τύπων! class myitem implements ITEM { } private int key; //το στοιχείο ως προς το οποίο ταξινοµούµε // εδώ µπορεί να υπάρχουν και άλλα πεδία... public boolean less(item w) {... return key < ((myitem) w).key; } Δοµές Δεδοµένων 07-15

16 Γενικές υλοποιήσεις Μπορούµε να έχουµε και ΑΤΔ για πίνακα στοιχείων Πίνακας στοιχείων άγνωστου τύπου Παρέχει τη δυνατότητα ταξινόµησης (υπο)πινάκων Διασύνδεση class myarray { } myarray(int) void rand() //παράγει τυχαία στοιχεία void read() //διαβάζει τον πίνακα από την είσοδο void show(int, int) //τυπώνει µέρος του πίνακα void sort(int, int) /*ταξινοµεί (υπο)πίνακα που καθορίζουν οι παράµετροι */ Δοµές Δεδοµένων 07-16

17 Γενικές υλοποιήσεις Παράδειγµα ενός προγράµµατος οδήγησης ταξινόµησης (driver program) class ArraySort { { } public static void main(string[] args) int N = Integer.parseInt(args[0]); myarray A = new myarray(n); if (args.length < 2) A.rand(); else A.read(); A.sort(0, N-1); A.show(0, N-1); } Δοµές Δεδοµένων 07-17

18 Γενικές υλοποιήσεις Παράδειγµα 2: τύποι ταξινόµησης εγγραφών Έστω µία τραπεζική εφαρµογή µε αντικείµενα που περιέχουν: Αριθµό λογαριασµού (int), όνοµα (String), υπόλοιπο (double) Αρχικά ορίζουµε την τάξη των εγγραφών Μπορούµε να επιλέξουµε το κλειδί ταξινόµησης Η SortKeyField δείχνει ποιο κλειδί θέλουµε class Record { } int id; //αριθµός λογαριασµού double balance; //υπόλοιπο String who; //όνοµα static int SortKeyField = 0; Δοµές Δεδοµένων 07-18

19 Γενικές υλοποιήσεις Παράδειγµα 2: τύποι ταξινόµησης εγγραφών Στη συνέχεια ορίζουµε την τάξη myitem Κληρονοµεί τη Record και υλοποιεί την ITEM Η less() ταξινοµεί ανάλογα µε τη SortKeyField class myitem extends Record implements ITEM { public boolean less(item w) { } myitem r = (myitem) w; switch (SortKeyField) { case 2: return who.compareto(r.who); case 1: return balance < r.balance; default: return id < r.id; } } Δοµές Δεδοµένων 07-19

20 Γενικές υλοποιήσεις Ιδιότητες γενικής υλοποίησης Λειτουργεί µε οποιονδήποτε τύπο αντικειµένων Όχι τόσο αποδοτική για ενσωµατωµένους τύπους Απαιτείται ένα πρόσθετο επίπεδο αναφορών Στην πράξη όµως εργαζόµαστε συνήθως µε αντικείµενα (π.χ. εγγραφές) και όχι µε στοιχειώδεις τύπους Υλοποιεί ταξινόµηση δεικτών Ταξινόµηση δεικτών Οι πίνακες αντικειµένων περιέχουν αναφορές Η αντιµετάθεση γίνεται σε επίπεδο αναφορών Αποφεύγεται η αντιγραφή των αντικειµένων Το κόστος της αντιµετάθεσης είναι µικρό Ανάλογο µε την αντιµετάθεση ακεραίων Δοµές Δεδοµένων 07-20

21 Στοιχειώδεις µέθοδοι: Ταξινόµηση φυσαλίδας Bubble Sort Λειτουργία αλγορίθµου Από τις πιο παλιές και απλοϊκές µεθόδους Σαρώνουµε από τα δεξιά προς τα αριστερά Αντιµεταθέτουµε γειτονικά στοιχεία όταν χρειάζεται Το µικρότερο στοιχείο φτάνει στο κάτω άκρο Το αριστερό όριο του πίνακα κινείται µία θέση δεξιά Επαναλαµβάνουµε την ίδια διαδικασία Μετά την επανάληψη i: ταξινοµηµένο το τµήµα a[p],,a[p+i] static void bubble(item[] a, int p, int r) { for (int i = p; i < r; i++) for (int j = r; j > i; j--) compexch(a, j-1, j); } Δοµές Δεδοµένων 07-21

22 Ταξινόµηση φυσαλίδας Bubble Sort Σχετικά αργή µέθοδος Πολλές αντιµεταθέσεις σε κάθε επανάληψη! Επιδέχεται βελτιστοποίηση (π.χ. αν δεν γίνουν αντιµεταθέσεις σε 1 επανάληψη) Πολυπλοκότητα Worst case: πίνακας σε φθίνουσα σειρά (N-1)+ (N-2) + +1 N 2 /2 = O(N 2 ) συγκρίσεις και αντιµεταθέσεις Average case: πιο πολύπλοκη η ανάλυση για τον ακριβή αριθµό αντιµεταθέσεων αλλά τελικά περίπου N 2 /2 = O(N 2 ) Σίγουρα απαιτούνται O(N 2 ) συγκρίσεις Δοµές Δεδοµένων 07-22

23 Ταξινόµηση µε επιλογή - Selection Sort Λειτουργία αλγορίθµου Εντοπίζουµε το µικρότερο στοιχείο του πίνακα Σαρώνουµε όλα τα στοιχεία µε τη σειρά Το αντιµεταθέτουµε µε αυτό στην πρώτη θέση Επαναλαµβάνουµε από την επόµενη θέση Κάθε πέρασµα µειώνει τη σάρωση κατά µία θέση static void selection(item[] a, int p, int r) { for (int i = p; i < r; i++) { int min = i; for (int j = i+1; j <= r; j++) if (less(a[j], a[min])) min = j;//εύρεση min exch(a, i, min); } } Δοµές Δεδοµένων 07-23

24 Ταξινόµηση µε επιλογή - Selection Sort Αναπαράσταση αλγορίθµου Μπορούµε να το σκεφτούµε σαν να χωρίζουµε τον πίνακα σε δύο τµήµατα Αριστερός υποπίνακας: ταξινοµηµένος Δεξιός υποπίνακας: µη ταξινοµηµένος Σε κάθε πέρασµα: Εντοπίζουµε το µικρότερο στοιχείο στον δεξιό υποπίνακα Το ενσωµατώνουµε στον αριστερό υποπίνακα Πολυπλοκότητα της Selection Sort Δεν µπορούµε να δούµε αν βρήκαµε ήδη το ελάχιστο στοιχείο Worst case: Ο(Ν) αντιµεταθέσεις, O(N 2 ) συγκρίσεις,, π.χ. φθίνουσα σειρά Οι αντιµεταθέσεις είναι πάντα Ο(Ν) Average case: O(N 2 ) (πάντα κάνει O(N 2 ) συγκρίσεις) Δοµές Δεδοµένων 07-24

25 Ταξινόµηση µε εισαγωγή Insertion Sort Την είδαµε στην αρχή αυτής της ενότητας Στην επανάληψη i, βάζουµε το a[i] στη σωστή θέση static void sort(item[] a, int p, int r) { Πολυπλοκότητα O(N 2 ) Πιθανές βελτιστοποιήσεις: for (int i = p+1; i <= r; i++) for (int j = i; j > p; j--) compexch(a, j-1, j); } } Μπορούµε να σταµατήσουµε να εκτελούµε την compexch όταν το κλειδί µπει στη σωστή θέση Διαδοχικές αντιµεταθέσεις που αφορούν το ίδιο στοιχείο δεν είναι αποδοτικές Ο έλεγχος στο 2 ο for µπορεί να αποφευχθεί µε χρήση στοιχείου φρουρού Δοµές Δεδοµένων 07-25

26 Ταξινόµηση µε εισαγωγή Insertion Sort static void insertion(item[] a, int p, int r) { int i; // τοποθέτηση του ελάχιστου στην πρώτη θέση (φρουρός) for (i = r; i > p; i--) compexch(a, i-1, i); for (i = p+2; i <= r; i++) { int j = i; ITEM v = a[i]; // δεν χρειάζεται πρόσθετος έλεγχος, το j δεν βγαίνει εκτός ορίων while (less(v, a[j-1])) { // µετακίνηση του j-1 και όχι αντιµετάθεση a[j] = a[j-1]; j--; } a[j] = v; } //βάζουµε το v στη σωστή θέση } Δοµές Δεδοµένων 07-26

27 Ταξινόµηση µε εισαγωγή Insertion Sort Λειτουργία βελτιωµένου αλγορίθµου Πάλι µπορούµε να το σκεφτούµε σαν να χωρίζεται ο πίνακας σε υποπίνακες Αρχικά ελάχιστο στοιχείο πάει µπροστά Παίρνουµε το πρώτο στοιχείο του δεξιού Το εισάγουµε στο σωστό σηµείο του αριστερού Και συνεχίζουµε... Δοµές Δεδοµένων 07-27

28 Ταξινόµηση µε εισαγωγή Insertion Sort Βελτιώσεις ταξινόµησης µε εισαγωγή Μπορούµε να δούµε αν βρήκαµε τη σωστή θέση Ο αριστερός υποπίνακας είναι ήδη ταξινοµηµένος Δεν χρειάζονται χωριστοί έλεγχοι τερµατισµού Απλά βάζουµε το µικρότερο στοιχείο στην αρχή Παίζει το ρόλο φρουρού Δεν χρειάζονται πλήρεις αντιµεταθέσεις Αρκεί η µετακίνηση των στοιχείων µία θέση δεξιά Στο τέλος αντιγράφεται το αρχικό στοιχείο Πολυπλοκότητα Worst case: παραµένει O(N 2 ) (π.χ. όταν τα στοιχεία είναι σε φθίνουσα σειρά) Είναι όµως αρκετά πιο γρήγορη από την αρχική υλοποίηση Δοµές Δεδοµένων 07-28

29 Στοιχειώδεις Ταξινοµήσεις Για περισσότερες λεπτοµέρειες δείτε εδώ: Insertion Sort Selection Sort Bubble Sort Δοµές Δεδοµένων 07-29

30 Χαρακτηριστικά επιδόσεων Συγκρίσεις Worst Case Συγκρίσεις Average Case Αντιµεταθέσεις ή µετακινήσεις Worst Case Αντιµεταθέσεις ή µετακινήσεις Average Case Bubble Sort N 2 /2 N 2 /2 N 2 /2 N 2 /2 Selection Sort Insertion Sort N 2 /2 N 2 /2 N N N 2 /2 N 2 /4 N 2 /2 N 2 /4 Δοµές Δεδοµένων 07-30

31 Χαρακτηριστικά επιδόσεων Όλες οι στοιχειώδεις ταξινοµήσεις είναι O(N 2 ) Αυτό δεν σηµαίνει ότι είναι ίδιες όµως! Ταξινόµηση µε επιλογή Κάνει πάντοτε λίγες αντιµεταθέσεις Δεν εξαρτάται καθόλου από την είσοδο Δεν µπορεί να γίνει προσαρµοστική Για αρχεία µε πολύ µεγάλα στοιχεία και µικρά κλειδιά Το κόστος των µεταθέσεων κυριαρχεί επί των συγκρίσεων Η ταξινόµηση µε επιλογή είναι γραµµική Δοµές Δεδοµένων 07-31

32 Χαρακτηριστικά επιδόσεων Ταξινόµηση µε εισαγωγή (προσαρµοστική έκδοση) Οι συγκρίσεις σταµατάνε όταν το στοιχείο µπει στη θέση του Συγκρίσεις και µετακινήσεις πάνε µαζί Worst case έχει διπλάσια πολυπλοκότητα σε σχέση µε average case Ταξινόµηση φυσαλίδας Προσαρµοστική έκδοση: έλεγχος αν έγιναν αντιµεταθέσεις στην προηγούµενη επανάληψη του βρόχου Σταµατάµε όταν το αρχείο είναι ταξινοµηµένο Συγκρίσεις και αντιµεταθέσεις πάνε µαζί Insertion Sort και Bubble Sort αποδίδουν καλά σε πολλά µερικώς ταξινοµηµένα αρχεία που συναντώνται στην πράξη (όχι όµως και η Selection Sort) Δοµές Δεδοµένων 07-32

33 Χαρακτηριστικά επιδόσεων Αντιστροφή (Inversion): ένα ζεύγος κλειδιών εκτός σειράς : 2 inversions [το ζεύγος (6, 8) και το ζεύγος (7, 8)] Συνολικός αριθµός αντιστροφών: για κάθε στοιχείο µετράµε τα µεγαλύτερα κλειδιά αριστερά του Λίγες αντιστροφές σηµαίνει «µερικώς» ταξινοµηµένο αρχείο Όταν έχουµε Ο(1) πλήθος αντιστροφών ανά στοιχείο: Σε τέτοιες περιπτώσεις τα κλειδιά είναι «κοντά» στις τελικές τους θέσεις Οι ταξινοµήσεις εισαγωγής και φυσαλίδας είναι γραµµικές (Ο(Ν)) Ταξινόµηση µε εισαγωγή είναι πάντα ανάλογη µε το πλήθος των αντιστροφών Για ταξινόµηση φυσαλίδας απόδειξη πιο πολύπλοκη Τα ίδια ισχύουν κι όταν έχουµε µόνο ένα σταθερό πλήθος στοιχείων που δεν έχουν Ο(1) αντιστροφές Δοµές Δεδοµένων 07-33

34 Πειραµατική Μελέτη Στοιχεία τύπου int Στοιχεία µε κλειδιά τύπου int Στοιχεία µε κλειδιά τύπου string N S I* I B S I B S I B S: Selection Sort I*: Insertion Sort I: βελτιωµένη Insertion Sort B: Bubble Sort Δοµές Δεδοµένων 07-34

35 Ταξινόµηση Shellsort Προτάθηκε από τον Shell (1959) Επέκταση της Insertion Sort Μειονεκτήµατα προηγούµενων µεθόδων: Συγκρίσεις µόνο µεταξύ γειτονικών στοιχείων Αν το ελάχιστο είναι στο τέλος χρειάζονται πολλές µετακινήσεις ή αντιµεταθέσεις για να πάει στην αρχή Ιδέα: ταξινόµηση ανά h στοιχεία Δοµές Δεδοµένων 07-35

36 Ταξινόµηση Shellsort Ιδέα: ταξινόµηση ανά h στοιχεία Ένας πίνακας είναι h-sorted αν οι υποπίνακες a[0], a[h], a[2h],... a[1], a[h+1], a[2h+1],... a[2], a[h+2], a[2h+2], a[h-1], a[2h-1], a[3h-1],... είναι ταξινοµηµένοι Δοµές Δεδοµένων 07-36

37 Ταξινόµηση Shellsort Λειτουργία του αλγορίθµου: Ξεκινάµε µε κάποια µεγάλη τιµή του h Κάνουµε τον πίνακα h-sorted Ίδιος κώδικας µε Insertion Sort µε τους δείκτες στους βρόχους να αυξοµειώνονται κατά h Μειώνουµε την τιµή του h και επαναλαµβάνουµε Όταν το h γίνει 1, ουσιαστικά καταλήγουµε σε Insertion Sort αλλά µε πολύ µικρότερο αριθµό συγκρίσεων Ερώτηση: τι τιµές πρέπει να διαλέξουµε για το h? Ουσιαστικά χρειαζόµαστε µία ακολουθία τιµών Δοµές Δεδοµένων 07-37

38 Ταξινόµηση Shellsort Version που χρησιµοποιεί την ακολουθία 1, 4, 13, 40, 121, 364,... δηλαδή h i+1 = 3h i + 1 static void shell(item[] a, int p, int r) { int h; for (h = 1; h <= (r-l)/9; h = 3*h+1); for ( ; h > 0; h /= 3) //InsertionSort µε βήµα h for (int i = p+h; i <= r; i++) { int j = i; ITEM v = a[i]; while (j >= p+h && less(v, a[j-h])) { a[j] = a[j-h]; j -= h; } a[j] = v; } } Δοµές Δεδοµένων 07-38

39 Ταξινόµηση Shellsort h = 1, 4, 13, 40, Προτάθηκε από τον Knuth (1969) Περισσότερα για τον Knuth εδώ: Πρώτα γίνεται 13-ταξινόµηση Μετά 4-ταξινόµηση Και στο τέλος 1-ταξινόµηση, δηλαδή Insertion Sort Πολύ µικρότερος αριθµός συγκρίσεων κατά την Insertion Sort Μακρινές µετακινήσεις γίνονται στις µεγάλες τιµές του h Δοµές Δεδοµένων 07-39

40 Ταξινόµηση Shellsort - Πολυπλοκότητα Η πολυπλοκότητα εξαρτάται από την ακολουθία {h i } Δεν έχει βρεθεί ακόµα αποδεδειγµένα η καλύτερη ακολουθία (ανοιχτό ερευνητικό πρόβληµα) Στην πράξη χρησιµοποιούνται ακολουθίες που µειώνονται γεωµετρικά Με κατάλληλες ακολουθίες, η shellsort είναι αρκετά πιο γρήγορη από τις άλλες στοιχειώδεις ταξινοµήσεις Δοµές Δεδοµένων 07-40

41 Ταξινόµηση Shellsort - Πολυπλοκότητα Τι γνωρίζουµε µέχρι σήµερα: Ιδιότητα 1: Η shellsort µε την ακολουθία του Knuth 1, 4, 13, 40, εκτελεί λιγότερες από Ο(Ν 3/2 ) συγκρίσεις Ιδιότητα 2: Η shellsort µε την ακολουθία 1, 8, 23, 77, 281 (h i = 4 i i +1 ) εκτελεί λιγότερες από Ο(Ν 4/3 ) συγκρίσεις Ιδιότητα 3: Η shellsort µε την ακολουθία 1, 2, 3, 4, 6, 9, 8, 12, 18, 27, 16, 24, 36, 54, 81, εκτελεί λιγότερες από Ο(Ν (logn) 2 ) συγκρίσεις (Pratt 1971) Δοµές Δεδοµένων 07-41

42 Ταξινόµηση συνδεδεµένων λιστών Προσαρµογή ταξινοµήσεων πινάκων Βασικός κανόνας: τροποποιούµε δείκτες και όχι κόµβους Αλλάζουµε τη δοµή και όχι το περιεχόµενο της λίστας Selection Sort: προσαρµογή σε λίστες Λίστα εισόδου: µη ταξινοµηµένη Λίστα εξόδου: ταξινοµηµένη Εντοπισµός µέγιστου στοιχείου Το µέγιστο από όσα έχουν µείνει Αποσύνδεση από λίστα εισόδου Σύνδεση στην αρχή της εξόδου Μικρότερο από όσα υπάρχουν ήδη εκεί Λίστα εξόδου σε αύξουσα σειρά Δοµές Δεδοµένων 07-42

43 Ταξινόµηση συνδεδεµένων λιστών Χρήση κόµβου φρουρού στην αρχή της λίστας εισόδου private static Node findmax(node h) { for (Node t = h; t.next!= null; t = t.next) if (h.next.item < t.next.item) h = t; return h; } //επιστρέφει δείκτη στον προηγούµενο από max static Node sort(node h) { Node head = new Node(-1, h), out = null; while (head.next!= null) { Node max = findmax(head); Node t = max.next; max.next = t.next; //διαγραφή από λίστα εισόδου t.next = out; //προσθήκη στην κεφαλή της λίστας εξόδου out = t; } return out; } Δοµές Δεδοµένων 07-43

44 Καταµέτρηση µε αριθµοδείκτη (χωρίς συγκρίσεις) Ειδικές µορφές ταξινόµησης, όταν γνωρίζουµε περαιτέρω ιδιότητες Αποφυγή συγκρίσεων αν εκµεταλλευθούµε τις ιδιότητες των κλειδιών Παράδειγµα 1: Έστω N κλειδιά µε διακεκριµένες τιµές από 0 έως N-1 for (i = 0; i < N; i++) b[a[i].key] = a[i]; Παράδειγµα 2: Καταµέτρηση µε αριθµοδείκτη κλειδιού Έστω N κλειδιά που παίρνουν τιµές 0 ή 1 Πρώτη διέλευση: µέτρηση των στοιχείων µε κλειδί 0 και κλειδί 1 Χρήση πίνακα µετρητών, cnt[0], cnt[1] και πίνακα b µε Ν στοιχεία cnt[0]: δείχνει αρχικά την θέση που πρέπει να µπει το πρώτο 0 στον b cnt[1]: αρχικά η θέση που πρέπει να µπει το πρώτο στοιχείο µε κλειδί 1 στον b Δεύτερη διέλευση στον πίνακα: µεταφέρουµε κάθε κλειδί στη σωστή θέση στον b και αυξάνουµε τον αντίστοιχο µετρητή for (i = 0; i < N; i++) b[cnt[a[i].key]++] = a[i]; Δοµές Δεδοµένων 07-44

45 Καταµέτρηση µε αριθµοδείκτη Παράδειγµα 3: Γενίκευση σε µεγαλύτερο αριθµό κλειδιών Έστω N αντικείµενα µε τιµές κλειδιών από 0 έως M-1 Για ευκολία, έστω ότι τα κλειδιά είναι τα ίδια τα a[i] αντί για a[i].key Έστω ότι το M είναι πολύ µικρότερο από το N πιθανόν πολλά κλειδιά µε ίδιες τιµές Πρώτη διέλευση: µετράµε το πλήθος κλειδιών για κάθε διακριτή τιµή Χρήση ενός πίνακα µετρητών cnt[] M στοιχείων Χρήση πίνακα b για προσωρινή αποθήκευση των στοιχείων Μετατροπή των µετρητών σε αθροιστικούς, cnt[k] = πόσα στοιχεία έχουν κλειδί µικρότερο από k = θέση που πρέπει να µπει το πρώτο στοιχείο µε κλειδί k Δεύτερη διέλευση: µεταφέρουµε κάθε κλειδί στη σωστή θέση Ο αντίστοιχος µετρητής αυξάνεται Η θέση για το επόµενο θα δίνεται πάντα από τον µετρητή Στο τέλος αν χρειάζεται, µεταφέρουµε τα στοιχεία πίσω στον a Δοµές Δεδοµένων 07-45

46 Καταµέτρηση µε αριθµοδείκτη Σειρά περασµάτων στους πίνακες 1ο: αρχικοποίηση M µετρητών 2ο: µέτρηση κλειδιών 3ο: µετατροπή M µετρητών σε αθροιστικούς 4ο: µεταφορά N κλειδιών στις σωστές θέσεις 5ο: επαναφορά N κλειδιών στον αρχικό πίνακα static void distcount(int a[], int p, int r) { int i, j, cnt[] = new int[m]; int b[] = new int[a.length]; for (j = 0; j < M; j++) cnt[j] = 0; for (i = p; i <= r; i++) cnt[a[i]+1]++; for (j = 1; j < M; j++) cnt[j] += cnt[j-1]; for (i = p; i <= r; i++) b[cnt[a[i]]++] = a[i]; for (i = p; i <= r; i++) a[i] = b[i-p]; } Δοµές Δεδοµένων 07-46

47 Καταµέτρηση µε αριθµοδείκτη Πόσο εξοικονοµούµε µε την ταξινόµηση µε αριθµοδείκτη? Θεώρηµα: Η καταµέτρηση µε αριθµοδείκτη γίνεται σε χρόνο Ο(Ν), υπό την προϋπόθεση ότι το πλήθος των διαφορετικών τιµών των κλειδιών Μ είναι Ο(Ν) Αρκεί να δούµε τις πράξεις στους 5 βρόχους Κάθε βρόχος εκτελείται σε Ο(Μ) ή σε Ο(Ν) Συνολική πολυπλοκότητα είναι Ο(Μ+Ν), άρα Ο(Ν) Δοµές Δεδοµένων 07-47

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

Δοµές Δεδοµένων. 9η Διάλεξη Ταξινόµηση - Στοιχειώδεις µέθοδοι. Ε. Μαρκάκης Δοµές Δεδοµένων 9η Διάλεξη Ταξινόµηση - Στοιχειώδεις µέθοδοι Ε. Μαρκάκης Περίληψη Bubble Sort Selection Sort Insertion Sort Χαρακτηριστικά επιδόσεων Shellsort Ταξινόµηση συνδεδεµένων λιστών Δοµές Δεδοµένων

Διαβάστε περισσότερα

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

Δοµές Δεδοµένων. 8η Διάλεξη: Ταξινόµηση. Ε. Μαρκάκης Δοµές Δεδοµένων 8η Διάλεξη: Ταξινόµηση Ε. Μαρκάκης Υπενθύµιση Εργαστήρια την επόµενη εβδοµάδα Πρόγραµµα εργαστηρίων αναρτηµένο στο eclass Εργασία 1 θα αναρτηθεί την Τρίτη, παράδοση 20/11 Δοµές Δεδοµένων

Διαβάστε περισσότερα

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

Δοµές Δεδοµένων. 10η Διάλεξη Ταξινόµηση. E. Μαρκάκης Δοµές Δεδοµένων 10η Διάλεξη Ταξινόµηση E. Μαρκάκης Περίληψη Ταξινόµηση µε αριθµοδείκτη κλειδιού Ταξινόµηση µε συγχώνευση Αλγόριθµος Mergesort Διµερής συγχώνευση Αφηρηµένη επιτόπου συγχώνευση Αναλυτική

Διαβάστε περισσότερα

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

Αλγόριθμοι Ταξινόμησης Μέρος 1 Αλγόριθμοι Ταξινόμησης Μέρος 1 Μανόλης Κουμπαράκης 1 Το Πρόβλημα της Ταξινόμησης Το πρόβλημα της ταξινόμησης (sorting) μιας ακολουθίας στοιχείων με κλειδιά ενός γνωστού τύπου (π.χ., τους ακέραιους ή τις

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

Δοµές Δεδοµένων. 11η Διάλεξη Ταξινόµηση Quicksort και Ιδιότητες Δέντρων. Ε. Μαρκάκης Δοµές Δεδοµένων 11η Διάλεξη Ταξινόµηση Quicksort και Ιδιότητες Δέντρων Ε. Μαρκάκης Περίληψη Quicksort Χαρακτηριστικά επιδόσεων Μη αναδροµική υλοποίηση Δέντρα Μαθηµατικές ιδιότητες Δοµές Δεδοµένων 11-2

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Πίνακες Συµβόλων Κεφάλαιο 12 ( ) Ε. Μαρκάκης Επίκουρος Καθηγητής ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ Πίνακες Συµβόλων Κεφάλαιο 12 (12.1-12.4) Ε. Μαρκάκης Επίκουρος Καθηγητής Περίληψη Πίνακες συµβόλων Διεπαφή πίνακα συµβόλων Αναζήτηση µε αριθµοδείκτη Ακολουθιακή αναζήτηση Δυαδική αναζήτηση

Διαβάστε περισσότερα

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

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Ουρές προτεραιότητας Κεφάλαιο 9. Ε. Μαρκάκης Επίκουρος Καθηγητής ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ Ουρές προτεραιότητας Κεφάλαιο 9 Ε. Μαρκάκης Επίκουρος Καθηγητής Περίληψη Ουρές προτεραιότητας Στοιχειώδεις υλοποιήσεις Δοµή δεδοµένων σωρού Αλγόριθµοι σε σωρούς Ο αλγόριθµος heapsort Δοµές

Διαβάστε περισσότερα

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

Δοµές Δεδοµένων. 14η Διάλεξη Δέντρα Δυαδικής Αναζήτησης. Ε. Μαρκάκης Δοµές Δεδοµένων 14η Διάλεξη Δέντρα Δυαδικής Αναζήτησης Ε. Μαρκάκης Περίληψη Δέντρα Δυαδικής Αναζήτησης Υλοποιήσεις εισαγωγής και αναζήτησης Χαρακτηριστικά επιδόσεων ΔΔΑ Εισαγωγή στη ρίζα ΔΔΑ Υλοποιήσεις

Διαβάστε περισσότερα

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

5. Απλή Ταξινόμηση. ομές εδομένων. Χρήστος ουλκερίδης. Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων 5. Απλή Ταξινόμηση 2 ομές εδομένων 4 5 Χρήστος ουλκερίδης Τμήμα Ψηφιακών Συστημάτων 11/11/2016 Εισαγωγή Η

Διαβάστε περισσότερα

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

ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ. Ουρές προτεραιότητας Κεφάλαιο 9. Ε. Μαρκάκης Επίκουρος Καθηγητής ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ Ουρές προτεραιότητας Κεφάλαιο 9 Ε. Μαρκάκης Επίκουρος Καθηγητής Περίληψη Ουρές προτεραιότητας Στοιχειώδεις υλοποιήσεις Δοµή δεδοµένων σωρού Αλγόριθµοι σε σωρούς Ο αλγόριθµος heapsort Δοµές

Διαβάστε περισσότερα

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

ΠΛΗ111. Ανοιξη Μάθηµα 9 ο. Ταξινόµηση. Τµήµα Ηλεκτρονικών Μηχανικών και Μηχανικών Υπολογιστών Πολυτεχνείο Κρήτης ΠΛΗ111 οµηµένος Προγραµµατισµός Ανοιξη 2005 Μάθηµα 9 ο Ταξινόµηση Τµήµα Ηλεκτρονικών Μηχανικών και Μηχανικών Υπολογιστών Πολυτεχνείο Κρήτης Ταξινόµηση Εισαγωγή Selection sort Insertion sort Bubble sort

Διαβάστε περισσότερα

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

Δοµές Δεδοµένων. 4η Διάλεξη Στοιχειώδεις Δοµές Δεδοµένων: Πίνακες και Λίστες. Ε. Μαρκάκης Δοµές Δεδοµένων 4η Διάλεξη Στοιχειώδεις Δοµές Δεδοµένων: Πίνακες και Λίστες Ε. Μαρκάκης Εργαστήρια Ώρες εργαστηρίων Τέσσερα τµήµατα εργαστηρίων XXXX001-XXXX060, Δευτέρα 09:00-11:00 (CSLAB II) XXXX061-XXXX120,

Διαβάστε περισσότερα

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

Δοµές Δεδοµένων. 18η Διάλεξη Ισορροπηµένα δέντρα. Ε. Μαρκάκης Δοµές Δεδοµένων 18η Διάλεξη Ισορροπηµένα δέντρα Ε. Μαρκάκης Περίληψη Επανάληψη των Τυχαιοποιηµένων ΔΔΑ, Στρεβλών ΔΔΑ, Δέντρων 2-3-4 Δέντρα κόκκινου-µαύρου Λίστες Παράλειψης Χαρακτηριστικά επιδόσεων - συµπεράσµατα

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

Συλλογές, Στοίβες και Ουρές Συλλογές, Στοίβες και Ουρές Σε πολλές εφαρμογές μας αρκεί η αναπαράσταση ενός δυναμικού συνόλου με μια δομή δεδομένων η οποία δεν υποστηρίζει την αναζήτηση οποιουδήποτε στοιχείου. Συλλογή (bag) : Επιστρέφει

Διαβάστε περισσότερα

Σύνοψη Προηγούμενου. Πίνακες (Arrays) Πίνακες (Arrays): Βασικές Λειτουργίες. Πίνακες (Arrays) Ορέστης Τελέλης

Σύνοψη Προηγούμενου. Πίνακες (Arrays) Πίνακες (Arrays): Βασικές Λειτουργίες. Πίνακες (Arrays) Ορέστης Τελέλης Σύνοψη Προηγούμενου Πίνακες (Arrays Ορέστης Τελέλης telelis@unipi.gr Τμήμα Ψηφιακών Συστημάτων, Πανεπιστήμιο Πειραιώς Διαδικαστικά θέματα. Aντικείμενο Μαθήματος. Aντικείμενα, Κλάσεις, Μέθοδοι, Μεταβλητές.

Διαβάστε περισσότερα

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

ΟΙΚΟΝΟΜΙΚΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΑΘΗΝΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ. Δοµές Δεδοµένων ΟΝΟΜΑΤΕΠΩΝΥΜΟ: ΟΙΚΟΝΟΜΙΚΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΑΘΗΝΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ AM: Δοµές Δεδοµένων Πτυχιακή Εξεταστική Ιούλιος 2014 Διδάσκων : Ευάγγελος Μαρκάκης 09.07.2014 ΥΠΟΓΡΑΦΗ ΕΠΟΠΤΗ: Διάρκεια εξέτασης : 2 ώρες

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

Δοµές Δεδοµένων. 6η Διάλεξη Αναδροµικές Εξισώσεις και Αφηρηµένοι Τύποι Δεδοµένων. Ε. Μαρκάκης Δοµές Δεδοµένων 6η Διάλεξη Αναδροµικές Εξισώσεις και Αφηρηµένοι Τύποι Δεδοµένων Ε. Μαρκάκης Περίληψη Χρήση αναδροµικών εξισώσεων στην ανάλυση αλγορίθµων Αφηρηµένοι τύποι δεδοµένων Συλλογές στοιχείων Στοίβα

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

Ουρά Προτεραιότητας (priority queue) Ουρά Προτεραιότητας (priority queue) Δομή δεδομένων που υποστηρίζει δύο βασικές λειτουργίες : Εισαγωγή στοιχείου με δεδομένο κλειδί. Επιστροφή ενός στοιχείου με μέγιστο (ή ελάχιστο) κλειδί και διαγραφή

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

Στοιχειώδεις Δομές Δεδομένων Στοιχειώδεις Δομές Δεδομένων Τύποι δεδομένων στη Java Ακέραιοι (int, long) Αριθμοί κινητής υποδιαστολής (float, double) Χαρακτήρες (char) Δυαδικοί (boolean) Από τους παραπάνω μπορούμε να φτιάξουμε σύνθετους

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

Προγραµµατιστικές Τεχνικές

Προγραµµατιστικές Τεχνικές Εθνικό Μετσόβιο Πολυτεχνείο Σχολή Αγρονόµων Τοπογράφων Μηχανικών Προγραµµατιστικές Τεχνικές Βασίλειος Βεσκούκης ρ. Ηλεκτρολόγος Μηχανικός & Μηχανικός Υπολογιστών ΕΜΠ v.vescoukis@cs.ntua.gr Ρωµύλος Κορακίτης

Διαβάστε περισσότερα

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

Αναδρομικοί Αλγόριθμοι Αναδρομικός αλγόριθμος (recursive algorithm) Επιλύει ένα πρόβλημα λύνοντας ένα ή περισσότερα στιγμιότυπα του ίδιου προβλήματος. Αναδρομικός αλγόριθμος (recursive algorithm) Επιλύει ένα πρόβλημα λύνοντας

Διαβάστε περισσότερα

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

Δοµές Δεδοµένων. 3η Διάλεξη Στοιχειώδεις Δοµές Δεδοµένων: Πίνακες. Ε. Μαρκάκης Δοµές Δεδοµένων 3η Διάλεξη Στοιχειώδεις Δοµές Δεδοµένων: Πίνακες Ε. Μαρκάκης Αλλαγή αίθουσας Τις Παρασκευές 1-3, το µάθηµα θα γίνεται στη Δ23 Δοµές Δεδοµένων 03-2 Περίληψη Σύνοψη 1 ου κεφαλαίου Δοµικά

Διαβάστε περισσότερα

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

Δομές Δεδομένων και Αλγόριθμοι Δομές Δεδομένων και Αλγόριθμοι Χρήστος Γκόγκος ΤΕΙ Ηπείρου, Τμήμα Μηχανικών Πληροφορικής ΤΕ Χειμερινό Εξάμηνο 2014-2015 (Παρουσίαση 5) 1 / 17 Απόδοση προγραμμάτων Συχνά χρειάζεται να εκτιμηθεί η απόδοση

Διαβάστε περισσότερα

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

Δομές Δεδομένων & Αλγόριθμοι Δομές Δεδομένων & Αναζήτηση & Ταξινόμηση 1 Αναζήτηση Έχω έναν πίνακα Α με Ν στοιχεία. Πρόβλημα: Βρες αν το στοιχείο x ανήκει στον πίνακα Αν ο πίνακας είναι αταξινόμητος τότε μόνη λύση σειριακή αναζήτηση

Διαβάστε περισσότερα

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

Αλγόριθμοι Ταξινόμησης Μέρος 2 Αλγόριθμοι Ταξινόμησης Μέρος 2 Μανόλης Κουμπαράκης 1 Προχωρημένοι Αλγόριθμοι Ταξινόμησης Στη συνέχεια θα παρουσιάσουμε τρείς προχωρημένους αλγόριθμους ταξινόμησης: treesort, quicksort και mergesort. 2

Διαβάστε περισσότερα

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

Δοµές Δεδοµένων. 16η Διάλεξη Κατακερµατισµός. Ε. Μαρκάκης Δοµές Δεδοµένων 16η Διάλεξη Κατακερµατισµός Ε. Μαρκάκης Περίληψη Συναρτήσεις κατακερµατισµού Χωριστή αλυσίδωση Γραµµική διερεύνηση Διπλός κατακερµατισµός Δυναµικός κατακερµατισµός Προοπτική Δοµές Δεδοµένων

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων ομές εδομένων Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων 2. Πίνακες 45 23 28 95 71 19 30 2 ομές εδομένων 4 5 Χρήστος ουλκερίδης Τμήμα Ψηφιακών Συστημάτων 12/10/2017

Διαβάστε περισσότερα

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

Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων ομές εδομένων Πανεπιστήμιο Πειραιώς Σχολή Τεχνολογιών Πληροφορικής και Επικοινωνιών Τμήμα Ψηφιακών Συστημάτων 2. Πίνακες 45 23 28 95 71 19 30 2 ομές εδομένων 4 5 Χρήστος ουλκερίδης Τμήμα Ψηφιακών Συστημάτων 21/10/2016

Διαβάστε περισσότερα

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

Δομές Δεδομένων & Αλγόριθμοι Δομές Δεδομένων & Αναζήτηση & Ταξινόμηση 1 Αναζήτηση Έχω έναν πίνακα Α με Ν στοιχεία. Πρόβλημα: Βρες αν το στοιχείο x ανήκει στον πίνακα Αν ο πίνακας είναι αταξινόμητος τότε μόνη λύση σειριακή αναζήτηση

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

int Α[] = {4, 16, 22, 12, 9, 15, 10}; { 4, 9, 10, 12, 15, 16, 22 } Α[0]=4, Α[1]=9, Α[2]=10 { 4, 16,22, 12, 9, 15, 10} { 4, 12, 16, 22, 9, 15,16, 22 }

int Α[] = {4, 16, 22, 12, 9, 15, 10}; { 4, 9, 10, 12, 15, 16, 22 } Α[0]=4, Α[1]=9, Α[2]=10 { 4, 16,22, 12, 9, 15, 10} { 4, 12, 16, 22, 9, 15,16, 22 } ΤΑΞΙΝΟΜΗΣΗ- ΑΣΚΗΣΕΙΣ Οι μέθοδοι ταξινόμησης INSERTION, SELECTION και BUBBLE SORT με την ολοκλήρωσή τους θα έχουν σε κάθε θέση του πίνακα το σωστό στοιχείο x (ταξινόμηση με αύξουσα σειρά δηλ. στην θέση

Διαβάστε περισσότερα

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

Διάλεξη 08: Λίστες ΙΙ Κυκλικές Λίστες ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 1 Διάλεξη 08: Λίστες ΙΙ Κυκλικές Λίστες Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Κυκλικές Απλά Συνδεδεμένες Λίστες - Κυκλικές Διπλά Συνδεδεμένες

Διαβάστε περισσότερα

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

ΟΙΚΟΝΟΜΙΚΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΑΘΗΝΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ. Δοµές Δεδοµένων ΟΝΟΜΑΤΕΠΩΝΥΜΟ: ΟΙΚΟΝΟΜΙΚΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΑΘΗΝΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ AM: Δοµές Δεδοµένων Εξεταστική Ιανουαρίου 2014 Διδάσκων : Ευάγγελος Μαρκάκης 20.01.2014 ΥΠΟΓΡΑΦΗ ΕΠΟΠΤΗ: Διάρκεια εξέτασης : 2 ώρες και

Διαβάστε περισσότερα

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

Δοµές Δεδοµένων. 15η Διάλεξη Δέντρα Δυαδικής Αναζήτησης και Κατακερµατισµός. Ε. Μαρκάκης Δοµές Δεδοµένων 15η Διάλεξη Δέντρα Δυαδικής Αναζήτησης και Κατακερµατισµός Ε. Μαρκάκης Περίληψη Υλοποιήσεις άλλων λειτουργιών σε ΔΔΑ: Επιλογή k-οστού µικρότερου Διαµέριση Αφαίρεση στοιχείου Ένωση 2 δέντρων

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Πίνακες Κλάσεις και Αντικείμενα ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Πίνακες Κλάσεις και Αντικείμενα Μαθήματα από το πρώτο εργαστήριο Έλεγχος ισότητας για Strings: Διαβάζουμε το String option και θέλουμε ένα loop να συνεχίσει

Διαβάστε περισσότερα

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

Διάλεξη 07: Λίστες Ι Υλοποίηση & Εφαρμογές Διάλεξη 07: Λίστες Ι Υλοποίηση & Εφαρμογές Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Ευθύγραμμες Απλά Συνδεδεμένες Λίστες (εισαγωγή, εύρεση, διαγραφή) Ευθύγραμμες Διπλά Συνδεδεμένες Λίστες

Διαβάστε περισσότερα

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

Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 12: Δέντρα ΙΙ -Δυαδικά Δέντρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Δυαδικά Δένδρα - Δυαδικά Δένδρα Αναζήτησης(ΔΔΑ) - Εύρεση Τυχαίου, Μέγιστου, Μικρότερου στοιχείου - Εισαγωγή

Διαβάστε περισσότερα

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

Δοµές Δεδοµένων. 17η Διάλεξη Ισορροπηµένα δέντρα. Ε. Μαρκάκης Δοµές Δεδοµένων 17η Διάλεξη Ισορροπηµένα δέντρα Ε. Μαρκάκης Περίληψη Εισαγωγή Τυχαιοποιηµένα ΔΔΑ (Randomized Binary Search trees) Στρεβλά ΔΔΑ (Splay trees) Καθοδικά δέντρα 2-3-4 (Top-Down 2-3-4 trees)

Διαβάστε περισσότερα

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

Διάλεξη 09: Αλγόριθμοι Ταξινόμησης I Διάλεξη 09: Αλγόριθμοι Ταξινόμησης I Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Οι αλγόριθμοι ταξινόμησης: Α. SelectionSort Ταξινόμηση με Επιλογή Β. InsertionSort Ταξινόμηση με Εισαγωγή

Διαβάστε περισσότερα

Ταξινόμηση: Εισαγωγικά. Ταξινόμηση (Sor ng) Αλγόριθμοι Απλής Ταξινόμησης. Βασικά Βήματα των Αλγορίθμων

Ταξινόμηση: Εισαγωγικά. Ταξινόμηση (Sor ng) Αλγόριθμοι Απλής Ταξινόμησης. Βασικά Βήματα των Αλγορίθμων Ταξινόμηση: Εισαγωγικά Ταξινόμηση (Sor ng) Ορέστης Τελέλης Βασικό πρόβλημα για την Επιστήμη των Υπολογιστών. π.χ. αλφαβητική σειρά, πωλήσεις ανά τιμή, πόλεις με βάση πληθυσμό, Μπορεί να είναι ένα πρώτο

Διαβάστε περισσότερα

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

Δομές δεδομένων (2) Αλγόριθμοι Δομές δεδομένων (2) Αλγόριθμοι Παράγωγοι τύποι (struct) σύνοψη προηγουμένων Πίνακες: πολλές μεταβλητές ίδιου τύπου Παράγωγοι τύποι ή Δομές (struct): ομαδοποίηση μεταβλητών διαφορετικού τύπου struct Student

Διαβάστε περισσότερα

Σχεδίαση και Ανάλυση Αλγορίθμων

Σχεδίαση και Ανάλυση Αλγορίθμων Σχεδίαση και Ανάλυση Αλγορίθμων Ενότητα.0 Σταύρος Δ. Νικολόπουλος 06-7 Τμήμα Μηχανικών Η/Υ & Πληροφορικής Πανεπιστήμιο Ιωαννίνων Webpage: www.cs.uoi.gr/~stavros Ταξινόμηση Selection-Sort Bubble-Sort και

Διαβάστε περισσότερα

Εισ. Στην ΠΛΗΡΟΦΟΡΙΚΗ. Διάλεξη 7 η. Βασίλης Στεφανής

Εισ. Στην ΠΛΗΡΟΦΟΡΙΚΗ. Διάλεξη 7 η. Βασίλης Στεφανής Εισ. Στην ΠΛΗΡΟΦΟΡΙΚΗ Διάλεξη 7 η Βασίλης Στεφανής Αλγόριθμοι ταξινόμησης Στην προηγούμενη διάλεξη είδαμε: Binary search Λειτουργεί μόνο σε ταξινομημένους πίνακες Πώς τους ταξινομούμε? Πολλοί τρόποι. Ενδεικτικά:

Διαβάστε περισσότερα

Προγραµµατισµός 1 Ταξινόµηση - Αναζήτηση

Προγραµµατισµός 1 Ταξινόµηση - Αναζήτηση Προγραµµατισµός 1 Ταξινόµηση - Αναζήτηση 1 Ταξινόµηση! Δεδοµένα: Δίνεται ένας πίνακας data από N ακεραίους! Ζητούµενο: Να ταξινοµηθούν τα περιεχόµενα σε αύξουσα αριθµητική σειρά:!i : 0 data[i]

Διαβάστε περισσότερα

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

Αντικειµενοστρεφής Προγραµµατισµός 16 η διάλεξη Π. Σταθοπούλου pstath@ece.upatras.gr ή pstath@upatras.gr Οµάδα Α (Φοιτητές µε µονό αριθµό Μητρώου ) ιδασκαλία : Παρασκευή 11πµ-13µµ ΗΛ7 Φροντιστήριο : ευτέρα 11πµ-12πµ ΗΛ4 Προηγούµενη ιάλεξη

Διαβάστε περισσότερα

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

Τύποι Δεδομένων και Απλές Δομές Δεδομένων. Παύλος Εφραιμίδης V1.0 ( ) Τύποι Δεδομένων και Απλές Δομές Δεδομένων Παύλος Εφραιμίδης V1.0 (2014-01-13) Απλές Δομές Δεδομένων Στην ενότητα αυτή θα γνωρίσουμε ορισμένες απλές Δομές Δεδομένων και θα τις χρησιμοποιήσουμε για την αποδοτική

Διαβάστε περισσότερα

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

Quicksort. Πρόβλημα Ταξινόμησης. Μέθοδοι Ταξινόμησης. Συγκριτικοί Αλγόριθμοι Πρόβλημα Ταξινόμησης Quicksort Διδάσκοντες: Σ. Ζάχος, Δ. Φωτάκης Επιμέλεια διαφανειών: Δ. Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Είσοδος : ακολουθία n αριθμών (α 1, α 2,..., α n

Διαβάστε περισσότερα

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

Διάλεξη 06: Συνδεδεμένες Λίστες & Εφαρμογές Στοιβών και Ουρών ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 1 Διάλεξη 06: Συνδεδεμένες Λίστες & Εφαρμογές Στοιβών και Ουρών Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Υλοποίηση ΑΤΔ με Συνδεδεμένες Λίστες -

Διαβάστε περισσότερα

Initialize each person to be free. while (some man is free and hasn't proposed to every woman) { Choose such a man m w = 1 st woman on m's list to

Initialize each person to be free. while (some man is free and hasn't proposed to every woman) { Choose such a man m w = 1 st woman on m's list to Κεφάλαιο 2 Δοµές Δεδοµένων Ι Χρησιµοποιήθηκε υλικό από τις αγγλικές διαφάνειες του Kevin Wayne. 1 Δοµές Δεδοµένων Ι Στην ενότητα αυτή θα γνωρίσουµε ορισµένες Δοµές Δεδοµένων και θα τις χρησιµοποιήσουµε

Διαβάστε περισσότερα

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

Προγραμματισμός Ι (ΗΥ120) Προγραμματισμός Ι (ΗΥ120) Διάλεξη 10: Ταξινόμηση Πίνακα Αναζήτηση σε Ταξινομημένο Πίνακα Πρόβλημα Δίνεται πίνακας t από Ν ακεραίους. Ζητούμενο: να ταξινομηθούν τα περιεχόμενα του πίνακα σε αύξουσα αριθμητική

Διαβάστε περισσότερα

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

Διάλεξη 08: Λίστες ΙΙ Κυκλικές Λίστες ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 1 Διάλεξη 0: Λίστες ΙΙ Κυκλικές Λίστες Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Κυκλικές Απλά Συνδεδεμένες Λίστες - Κυκλικές Διπλά Συνδεδεμένες

Διαβάστε περισσότερα

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

ΠΛΗΡΟΦΟΡΙΑΚΑ & ΤΗΛΕΠΙΚΟΙΝΩΝΙΑΚΑ ΣΥΣΤΗΜΑΤΑ Οικονοµικό Πανεπιστήµιο Αθηνών Τµήµα ιοικητικής Επιστήµης & Τεχνολογίας ΠΛΗΡΟΦΟΡΙΑΚΑ & ΤΗΛΕΠΙΚΟΙΝΩΝΙΑΚΑ ΣΥΣΤΗΜΑΤΑ Κεφάλαιο 8 Προχωρηµένα Θέµατα Προγραµµατισµού C Γιώργος Γιαγλής Περίληψη Κεφαλαίου 8 Προχωρηµένα

Διαβάστε περισσότερα

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

Κεφάλαιο 6 Ουρές Προτεραιότητας Κεφάλαιο 6 Ουρές Προτεραιότητας Περιεχόμενα 6.1 Ο αφηρημένος τύπος δεδομένων ουράς προτεραιότητας... 114 6.2 Ουρές προτεραιότητας με στοιχειώδεις δομές δεδομένων... 115 6.3 Δυαδικός σωρός... 116 6.3.1

Διαβάστε περισσότερα

ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με Α.Μ. σε 3, 7, 8 & 9 22/11/07

ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με Α.Μ. σε 3, 7, 8 & 9 22/11/07 Ακαδ έτος 2007-2008 ΠΛΗΡΟΦΟΡΙΚΗ Ι Φερεντίνος 22/11/07 ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με ΑΜ σε 3, 7, 8 & 9 22/11/07 Παράδειγμα με if/else if και user input: import javautil*; public class Grades public

Διαβάστε περισσότερα

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

Δοµές Δεδοµένων. 7η Διάλεξη Αφηρηµένοι Τύποι Δεδοµένων. Ε. Μαρκάκης Δοµές Δεδοµένων 7η Διάλεξη Αφηρηµένοι Τύποι Δεδοµένων Ε. Μαρκάκης Περίληψη Στοίβα ώθησης προς τα κάτω Παραδείγµατα πελατών για στοίβες Υλοποιήσεις στοίβας µε πίνακες και λίστες Γενικές υλοποιήσεις Ουρές

Διαβάστε περισσότερα

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

ΕΝΟΤΗΤΑ 6 ΛΙΣΤΕΣ ΠΑΡΑΛΕΙΨΗΣ (SKIP LISTS) ΕΝΟΤΗΤΑ 6 ΛΙΣΤΕΣ ΠΑΡΑΛΕΙΨΗΣ (SKIP LISTS) Ταχεία Αναζήτηση Σε πίνακα: δυαδική αναζήτηση (binary search) σε ταξινοµηµένο πίνακα O(log n) Σε δένδρο: αναζήτηση σε ισοζυγισµένο δένδρο O(log n) Σε λίστα: Μπορούµε

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

Διάλεξη 12: Δέντρα ΙΙ Δυαδικά Δέντρα Διάλεξη 12: Δέντρα ΙΙ Δυαδικά Δέντρα Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: Δυαδικά Δένδρα Δυαδικά Δένδρα Αναζήτησης (ΔΔΑ) Εύρεση Τυχαίου, Μέγιστου, Μικρότερου στοιχείου Εισαγωγή στοιχείου

Διαβάστε περισσότερα

Ταξινόμηση κάδου και ταξινόμηση Ρίζας Bucket-Sort και Radix-Sort

Ταξινόμηση κάδου και ταξινόμηση Ρίζας Bucket-Sort και Radix-Sort Ταξινόμηση κάδου και ταξινόμηση Ρίζας Bucket-Sort και Radix-Sort 1, c 3, a 3, b 7, d 7, g 7, e B 0 1 3 4 5 6 7 8 9 1 BucketSort (Ταξινόμηση Κάδου) - Αρχικά θεωρείται ένα κριτήριο κατανομής με βάση το οποίο

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

Δοµές Δεδοµένων. 12η Διάλεξη Διάσχιση Δέντρων και Ουρές Προτεραιότητας. Ε. Μαρκάκης Δοµές Δεδοµένων 12η Διάλεξη Διάσχιση Δέντρων και Ουρές Προτεραιότητας Ε. Μαρκάκης Περίληψη Διάσχιση δέντρων Ουρές προτεραιότητας Στοιχειώδεις υλοποιήσεις Δοµή δεδοµένων σωρού Αλγόριθµοι σε σωρούς Ο αλγόριθµος

Διαβάστε περισσότερα

Πληροφορική 2. Αλγόριθμοι

Πληροφορική 2. Αλγόριθμοι Πληροφορική 2 Αλγόριθμοι 1 2 Τι είναι αλγόριθμος; Αλγόριθμος είναι ένα διατεταγμένο σύνολο από σαφή βήματα το οποίο παράγει κάποιο αποτέλεσμα και τερματίζεται σε πεπερασμένο χρόνο. Ο αλγόριθμος δέχεται

Διαβάστε περισσότερα

ιαφάνειες παρουσίασης #4

ιαφάνειες παρουσίασης #4 ΠΡΟΓΡΑΜΜΑΤΙΣΤΙΚΕΣ ΤΕΧΝΙΚΕΣ http://www.softlab.ntua.gr/~nickie/courses/progtech/ ιδάσκοντες: Γιάννης Μαΐστρος (maistros@cs.ntua.gr) Στάθης Ζάχος (zachos@cs.ntua.gr) (nickie@softlab.ntua.gr) ιαφάνειες παρουσίασης

Διαβάστε περισσότερα

Η εφαρµογή xsortlab. Οπτικός τρόπος ταξινόµησης

Η εφαρµογή xsortlab. Οπτικός τρόπος ταξινόµησης Η εφαρµογή xsortlab Η ταξινόµηση µιας λίστας πραγµάτων είτε σε αύξουσα είτε σε φθίνουσα σειρά είναι µια πολύ σηµαντική λειτουργία. Η εφαρµογή xsortlab περικλείει 5 διαφορετικές µεθόδους ταξινόµησης. Την

Διαβάστε περισσότερα

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

Δομές Δεδομένων. Δημήτρης Μιχαήλ. Ταξινόμηση. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Δομές Δεδομένων Ταξινόμηση Δημήτρης Μιχαήλ Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Το πρόβλημα Είσοδος n αντικείμενα a 1, a 2,..., a n με κλειδιά (συνήθως σε ένα πίνακα, ή λίστα, κ.τ.λ)

Διαβάστε περισσότερα

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

ΠΑΡΑΡΤΗΜΑ: QUIZ ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ ΠΑΡΑΡΤΗΜΑ: QUIZ ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ (Οι ερωτήσεις µε κίτρινη υπογράµµιση είναι εκτός ύλης για φέτος) ΕΙΣΑΓΩΓΗ Q1. Οι Πρωταρχικοί τύποι (primitive types) στη Java 1. Είναι όλοι οι ακέραιοι και όλοι οι πραγµατικοί

Διαβάστε περισσότερα

Προγραμματιστικές Τεχνικές

Προγραμματιστικές Τεχνικές Εθνικό Μετσόβιο Πολυτεχνείο Σχολή Αγρονόμων Τοπογράφων Μηχανικών Προγραμματιστικές Τεχνικές Βασίλειος Βεσκούκης Δρ. Ηλεκτρολόγος Μηχανικός & Μηχανικός Υπολογιστών ΕΜΠ v.vescoukis@cs.ntua.gr Ρωμύλος Κορακίτης

Διαβάστε περισσότερα

3 ΑΝΑ ΡΟΜΗ ΑΝΑΖΗΤΗΣΗ - ΤΑΞΙΝΟΜΗΣΗ. n! = 1*2*3*..(n-1)*n. n! = 1 αν n = 0, = n*(n-1)! αν n > ΑΝΑ ΡΟΜΗ Εισαγωγή

3 ΑΝΑ ΡΟΜΗ ΑΝΑΖΗΤΗΣΗ - ΤΑΞΙΝΟΜΗΣΗ. n! = 1*2*3*..(n-1)*n. n! = 1 αν n = 0, = n*(n-1)! αν n > ΑΝΑ ΡΟΜΗ Εισαγωγή 3 ΑΝΑ ΡΟΜΗ ΑΝΑΖΗΤΗΣΗ - ΤΑΞΙΝΟΜΗΣΗ 3.1 ΑΝΑ ΡΟΜΗ 3.1.1 Εισαγωγή ΕΦΑΡΜΟΣΜΕΝΗ ΠΛΗΡΟΦΟΡΙΚΗ ΙΙ Αναδροµή είναι η µέθοδος κατά την οποία, σε µία γλώσσα προγραµµατισµού, µία διαδικασία ή συνάρτηση έχει την δυνατότητα

Διαβάστε περισσότερα

Στόχοι και αντικείμενο ενότητας. Πέρασμα Πίνακα σε Συνάρτηση (συν.) Πέρασμα Πίνακα σε Συνάρτηση. #8.. Ειδικά Θέματα Αλγορίθμων

Στόχοι και αντικείμενο ενότητας. Πέρασμα Πίνακα σε Συνάρτηση (συν.) Πέρασμα Πίνακα σε Συνάρτηση. #8.. Ειδικά Θέματα Αλγορίθμων Στόχοι και αντικείμενο ενότητας Πέρασμα Πίνακα σε Συνάρτηση #8.. Ειδικά Θέματα Αλγορίθμων Προβλήματα Αναζήτησης Γραμμική Αναζήτηση (Linear Search) Ενημέρωση Μέτρηση Δυαδική Αναζήτηση (Binary Search) Προβλήματα

Διαβάστε περισσότερα

ΣΧΟΛΗ ΔΙΟΙΚΗΣΗΣ ΚΑΙ ΟΙΚΟΝΟΜΙΑΣ ΤΜΗΜΑ ΔΙΟΙΚΗΣΗΣ ΕΠΙΧΕΙΡΗΣΕΩΝ (ΠΑΤΡΑ) ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ

ΣΧΟΛΗ ΔΙΟΙΚΗΣΗΣ ΚΑΙ ΟΙΚΟΝΟΜΙΑΣ ΤΜΗΜΑ ΔΙΟΙΚΗΣΗΣ ΕΠΙΧΕΙΡΗΣΕΩΝ (ΠΑΤΡΑ) ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ ΣΧΟΛΗ ΔΙΟΙΚΗΣΗΣ ΚΑΙ ΟΙΚΟΝΟΜΙΑΣ ΤΜΗΜΑ ΔΙΟΙΚΗΣΗΣ ΕΠΙΧΕΙΡΗΣΕΩΝ (ΠΑΤΡΑ) ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ Γιάννης Κουτσονίκος Επίκουρος Καθηγητής Οργάνωση Δεδομένων Δομή Δεδομένων: τεχνική οργάνωσης των δεδομένων με σκοπό την

Διαβάστε περισσότερα

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

Αλγόριθµοι και Πολυπλοκότητα Αλγόριθµοι και Πολυπλοκότητα Ν. Μ. Μισυρλής Τµήµα Πληροφορικής και Τηλεπικοινωνιών, Πανεπιστήµιο Αθηνών Καθηγητής: Ν. Μ. Μισυρλής () Αλγόριθµοι και Πολυπλοκότητα Φεβρουαρίου 0 / ένδρα Ενα δένδρο είναι

Διαβάστε περισσότερα

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

Αλγόριθμοι Ταξινόμησης Μέρος 4 Αλγόριθμοι Ταξινόμησης Μέρος 4 Μανόλης Κουμπαράκης Δομές Δεδομένων και Τεχνικές 1 Μέθοδοι Ταξινόμησης Βασισμένοι σε Συγκρίσεις Κλειδιών Οι αλγόριθμοι ταξινόμησης που είδαμε μέχρι τώρα αποφασίζουν πώς να

Διαβάστε περισσότερα

ΠΑΝΕΠΙΣΤΗΜΙΟ ΠΕΙΡΑΙΩΣ ΣΧΟΛΗ ΤΕΧΝΟΛΟΓΙΩΝ ΠΛΗΡΟΦΟΡΙΚΗΣ ΚΑΙ ΕΠΙΚΟΙΝΩΝΙΩΝ ΤΜΗΜΑ ΨΗΦΙΑΚΩΝ ΣΥΣΤΗΜΑΤΩΝ «ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ»

ΠΑΝΕΠΙΣΤΗΜΙΟ ΠΕΙΡΑΙΩΣ ΣΧΟΛΗ ΤΕΧΝΟΛΟΓΙΩΝ ΠΛΗΡΟΦΟΡΙΚΗΣ ΚΑΙ ΕΠΙΚΟΙΝΩΝΙΩΝ ΤΜΗΜΑ ΨΗΦΙΑΚΩΝ ΣΥΣΤΗΜΑΤΩΝ «ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ» ΠΑΝΕΠΙΣΤΗΜΙΟ ΠΕΙΡΑΙΩΣ ΣΧΟΛΗ ΤΕΧΝΟΛΟΓΙΩΝ ΠΛΗΡΟΦΟΡΙΚΗΣ ΚΑΙ ΕΠΙΚΟΙΝΩΝΙΩΝ ΤΜΗΜΑ ΨΗΦΙΑΚΩΝ ΣΥΣΤΗΜΑΤΩΝ «ΔΟΜΕΣ ΔΕΔΟΜΕΝΩΝ» ΗΜΕΡ.ΑΝΑΘΕΣΗΣ: Δευτέρα 21 Δεκεμβρίου 2015 ΗΜΕΡ.ΠΑΡΑΔΟΣΗΣ: Δευτέρα 25 Ιανουαρίου 2016 Διδάσκοντες:

Διαβάστε περισσότερα

p

p ΑΝΑ ΡΟΜΙΚΗ ΤΑΞΙΝΟΜΗΣΗ- ΑΣΚΗΣΕΙΣ Οι μέθοδοι ταξινόμησης QUICK SORT και MERGE SORT κωδικοποιούνται εύκολα αναδρομικά Oι δυο αναδροµικοί µέθοδοι δέχονται 1ο όρισµα τον πίνακα, και δεν επιστρέφουν τίποτα.

Διαβάστε περισσότερα

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

Διαδικασιακός Προγραμματισμός Τμήμα ΜΗΧΑΝΙΚΩΝ ΠΛΗΡΟΦΟΡΙΚΗΣ ΤΕ ΤΕΙ ΔΥΤΙΚΗΣ ΕΛΛΑΔΑΣ Διαδικασιακός Προγραμματισμός Διάλεξη 12 η Αναζήτηση/Ταξινόμηση Πίνακα Οι διαλέξεις βασίζονται στο βιβλίο των Τσελίκη και Τσελίκα C: Από τη Θεωρία στην

Διαβάστε περισσότερα

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

Οργάνωση αρχείων: πως είναι τοποθετηµένες οι εγγραφές ενός αρχείου όταν αποθηκεύονται στο δίσκο Κατακερµατισµός 1 Οργάνωση Αρχείων (σύνοψη) Οργάνωση αρχείων: πως είναι τοποθετηµένες οι εγγραφές ενός αρχείου όταν αποθηκεύονται στο δίσκο 1. Αρχεία Σωρού 2. Ταξινοµηµένα Αρχεία Φυσική διάταξη των εγγραφών

Διαβάστε περισσότερα

Επαναληπτικές δοµές. µτ α.τ. Όχι. ! απαγορεύεται µέσα σε µία ΓΙΑ να µεταβάλλουµε τον µετρητή! διότι δεν θα ξέρουµε µετά πόσες επαναλήψεις θα γίνουν

Επαναληπτικές δοµές. µτ α.τ. Όχι. ! απαγορεύεται µέσα σε µία ΓΙΑ να µεταβάλλουµε τον µετρητή! διότι δεν θα ξέρουµε µετά πόσες επαναλήψεις θα γίνουν Επαναληπτικές δοµές Η λογική των επαναληπτικών διαδικασιών εφαρµόζεται όπου µία ακολουθία εντολών εφαρµόζεται σε ένα σύνολο περιπτώσεων που έχουν κάτι κοινό. Όταν ψάχνουµε θέση για να παρκάρουµε κοντά

Διαβάστε περισσότερα

Εργαστηριακή Άσκηση 1

Εργαστηριακή Άσκηση 1 Εργαστηριακή Άσκηση 1 Επανάληψη προγραμματισμού Βασικοί Αλγόριθμοι Είσοδος τιμών από το πληκτρολόγιο Σε όλα τα προγράμματα που θα γράψουμε στην συνέχεια του εξαμήνου θα χρειαστεί να εισάγουμε τιμές σε

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Πίνακες Κλάσεις και Αντικείμενα ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Πίνακες Κλάσεις και Αντικείμενα Μαθήματα από το πρώτο εργαστήριο Δημιουργία αντικειμένου Scanner Scanner input = new Scanner(System.in); Το αντικείμενο input

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

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

Διαβάστε περισσότερα

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

ΕΠΛ 231 οµές εδοµένων και Αλγόριθµοι Άννα Φιλίππου, 2006 9-1 Σωροί Στην ενότητα αυτή θα µελετηθούν τα εξής επιµέρους θέµατα: Ουρές Προτεραιότητας Σωροί υλοποίηση και πράξεις Ο αλγόριθµος ταξινόµησης HeapSort Παραλλαγές Σωρών ΕΠΛ 231 οµές εδοµένων και Αλγόριθµοι

Διαβάστε περισσότερα

Ταξινόμηση. 1. Ταξινόμηση του Shell. Εισαγωγή στην Ανάλυση Αλγορίθμων Μάγια Σατρατζέμη

Ταξινόμηση. 1. Ταξινόμηση του Shell. Εισαγωγή στην Ανάλυση Αλγορίθμων Μάγια Σατρατζέμη Ταξινόμηση. Ταξινόμηση του Shell Εισαγωγή στην Ανάλυση Αλγορίθμων Μάγια Σατρατζέμη Ταξινόμηση του Shell Η μέθοδος που προτάθηκε από τον Shell έχει βασικό χαρακτηριστικό ότι χρησιμοποιεί µία ακολουθία ακεραίων

Διαβάστε περισσότερα

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

Διάλεξη 08: ΛίστεςΙΙ Κυκλικές Λίστες. Διδάσκων: Παναγιώτης Ανδρέου Διάλεξη 0: ΛίστεςΙΙ Κυκλικές Λίστες Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: - Κυκλικές Απλά Συνδεδεμένες Λίστες - Κυκλικές Διπλά Συνδεδεμένες Λίστες - Τεχνικές Μείωσης Χώρου Διδάσκων:

Διαβάστε περισσότερα

242 -ΕισαγωγήστουςΗ/Υ

242 -ΕισαγωγήστουςΗ/Υ 1 242 -ΕισαγωγήστουςΗ/Υ ΤµήµαΜαθηµατικών, Πανεπιστήµιο Ιωαννίνων Άρτια Α.Μ. (0-2-4-6-8) 2 ήλωση: Πίνακες στην ΕΑΓ δηλωση ( [1 : 1, 1 : 2,..., 1: ν ] ) παραταξη ; Π.χ.: δηλωση

Διαβάστε περισσότερα

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

Ενότητες 3 & 4: Δένδρα, Σύνολα & Λεξικά Ασκήσεις και Λύσεις Ενότητες 3 & 4: Δένδρα, Σύνολα & Λεξικά Ασκήσεις και Λύσεις Άσκηση 1 Γράψτε μία αναδρομική συνάρτηση που θα παίρνει ως παράμετρο ένα δείκτη στη ρίζα ενός δυαδικού δένδρου και θα επιστρέφει το βαθμό του

Διαβάστε περισσότερα

Δείκτες & Πίνακες Δείκτες, Πίνακες

Δείκτες & Πίνακες Δείκτες, Πίνακες Δείκτες & Πίνακες Δείκτες, Πίνακες Δείκτες Δείκτης είναι μια μεταβλητή που ως δεδομένο περιέχει τη θέση μνήμης (διεύθυνση) μιας άλλης μεταβλητής. Μεταβλητές Τιμές. (*) Δείκτης p Μεταβλητή v Δ1. Δ2. τιμή

Διαβάστε περισσότερα

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

Διαίρει-και-Βασίλευε. Αλγόριθµοι & Πολυπλοκότητα (Χειµώνας 2011) Διαίρει-και-Βασίλευε 2 Διαίρει-και-Βασίλευε Αλγόριθµοι & Πολυπλοκότητα (Χειµώνας 2011) Διαίρει-και-Βασίλευε 2 Διαίρει-και-Βασίλευε Γενική µέθοδος σχεδιασµού αλγορίθµων: Διαίρεση σε ( 2) υποπροβλήµατα (σηµαντικά) µικρότερου µεγέθους.

Διαβάστε περισσότερα