Ανάλυση αλγορίθμων Παράμετροι απόδοσης ενός αλγόριθμου: Χρόνος εκτέλεσης Απαιτούμενοι πόροι, π.χ. μνήμη, επικοινωνία (π.χ. σε κατανεμημένα συστήματα) Προσπάθεια.

Slides:



Advertisements
Παρόμοιες παρουσιάσεις
Αναδρομικοί Αλγόριθμοι
Advertisements

Δομές Δεδομένων και Αλγόριθμοι
Δένδρα van Emde Boas TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Μελετάμε την περίπτωση όπου αποθηκεύουμε.
Επίπεδα Γραφήματα (planar graphs)
Στοιχειώδεις Δομές Δεδομένων TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Τύποι δεδομένων στη Java • Ακέραιοι.
Λίστες παράλειψης (skip lists) TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A
Άμεσοι Αλγόριθμοι: Προσπέλαση Λίστας (list access) TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Έχουμε αποθηκεύσει.
Ανακτηση Πληροφοριασ σε νεφη Υπολογιστων
Επίπεδα Γραφήματα : Προβλήματα και Υπολογιστική Πολυπλοκότητα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A AA.
Πολυπλοκότητα Παράμετροι της αποδοτικότητας ενός αλγόριθμου:
ΤΕΧΝΙΚΕΣ Αντικειμενοστραφουσ προγραμματισμου
Ισορροπημένα Δένδρα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Μπορούμε να επιτύχουμε χρόνο εκτέλεσης για.
Δομές Αναζήτησης TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A εισαγωγή αναζήτησηεπιλογή διατεταγμένος πίνακας.
Ψηφιακά Δένδρα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Μπορούμε να χρησιμοποιήσουμε την παραπάνω αναπαράσταση.
Δένδρα Αναζήτησης Πολλαπλής Διακλάδωσης TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Δένδρα στα οποία κάθε.
Εισαγωγικές Έννοιες Διδάσκοντες: Σ. Ζάχος, Δ. Φωτάκης Επιμέλεια διαφανειών: Δ. Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό Μετσόβιο.
ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Συλλογές.
Διαίρει και Βασίλευε πρόβλημα μεγέθους Ν διάσπαση πρόβλημα μεγέθους Ν-k πρόβλημα μεγέθους k.
Κοντινότεροι Κοινοί Πρόγονοι α βγ θ δεζ η π ν ι κλμ ρσ τ κκπ(λ,ι)=α, κκπ(τ,σ)=ν, κκπ(λ,π)=η κκπ(π,σ)=γ, κκπ(ξ,ο)=κ ξο κκπ(ι,ξ)=β, κκπ(τ,θ)=θ, κκπ(ο,μ)=α.
Προσεγγιστικοί Αλγόριθμοι
Μέγιστη ροή TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A AA A A Συνάρτηση χωρητικότητας Κατευθυνόμενο γράφημα.
Αριθμοθεωρητικοί Αλγόριθμοι TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A AA A A Αλγόριθμοι που επεξεργάζονται.
Τυχαιοκρατικοί Αλγόριθμοι TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA Πιθανότητες και Αλγόριθμοι Ανάλυση μέσης.
Ισορροπημένα Δένδρα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Μπορούμε να επιτύχουμε χρόνο εκτέλεσης για.
TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός πρόβλημα μεγέθους Ν διάσπαση πρόβλημα.
Δομές Αναζήτησης TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Χειριζόμαστε ένα σύνολο στοιχείων όπου το κάθε.
Ελαφρύτατες διαδρομές TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A AA A A Συνάρτηση βάρους Κατευθυνόμενο γράφημα.
ΔΕΞΙΟΤΗΤΕΣ ΕΠΙΚΟΙΝΩΝΙΑΣ 1 ΠΕΡΙΓΡΑΦΗ ΤΩΝ ΜΝΗΜΩΝ ΕΝΟΣ Η/Υ ΤΜΗΜΑ: Τ6 ΟΝΟΜΑΤΑ: ΣΕΛΑΛΜΑΖΙΔΗΣ ΤΑΣΟΣ ΦΙΛΙΑΣ ΑΝΤΩΝΗΣ ΦΙΛΙΑΣ ΑΝΤΩΝΗΣ ΤΕΧΝΟΛΟΓΙΚΟ ΕΚΠΑΙΔΕΥΤΙΚΟ ΙΔΡΥΜΑ.
Ισορροπημένα Δένδρα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Μπορούμε να επιτύχουμε χρόνο εκτέλεσης για.
Ψηφιακά Δένδρα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Μπορούμε να χρησιμοποιήσουμε την παραπάνω αναπαράσταση.
City Driver Assistant. Καθημερινά Προβλήματα Υπερβολική Κίνηση και Συμφόρηση ιδιαίτερα κατά τις ώρες αιχμής. ‘Αδικία’ των φαναριών, π.χ. όταν δεν υπάρχουν.
Παράλληλοι Επιστημονικοί Υπολογισμοί Τομέας Θεωρητικής Πληροφορικής Τμήμα Πληροφορικής και Τηλεπικοινωνιών Εθνικό και Καποδιστριακό Πανεπιστημίο Αθηνών.
2-1 Ανάλυση Αλγορίθμων Αλγόριθμος Πεπερασμένο σύνολο εντολών που, όταν εκτελεστούν, επιτυγχάνουν κάποιο επιθυμητό αποτέλεσμα –Δεδομένα εισόδου και εξόδου.
Δυναμικά Σύνολα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A AA A A Δυναμικό σύνολο Tα στοιχεία του μεταβάλλονται.
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) Δομή δεδομένων που υποστηρίζει.
Ειδικά Θέματα Αλγορίθμων και Δομών Δεδομένων
Διερεύνηση γραφήματος. Ένας αλγόριθμος διερεύνησης γραφήματος επισκέπτεται τους κόμβους του γραφήματος με μια καθορισμένη στρατηγική, π.χ. κατά εύρος.
Δυναμικά Σύνολα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A AA A A Δυναμικό σύνολο Tα στοιχεία του μεταβάλλονται.
Ελαφρύτατες διαδρομές TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A AA A A.
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 AA A A Μια εταιρεία παράγει κέικ δύο κατηγοριών,
Δομές Αναζήτησης TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Θέλουμε να υποστηρίξουμε δύο βασικές λειτουργίες:
Στοιχειώδεις Δομές Δεδομένων TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Τύποι δεδομένων στη C Ακέραιοι.
Επίπεδα Γραφήματα: Έλεγχος Επιπεδότητας TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A AA A A αβ ζ η ε γ θ Το γράφημα.
Διερεύνηση γραφήματος. Ένας αλγόριθμος διερεύνησης γραφήματος επισκέπτεται τους κόμβους του γραφήματος με μια καθορισμένη στρατηγική, π.χ. κατά εύρος.
Quicksort Διδάσκοντες: Σ. Ζάχος, Δ. Φωτάκης Επιμέλεια διαφανειών: Δ. Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό Μετσόβιο Πολυτεχνείο.
Αλγόριθμοι - Τμήμα Πληροφορικής ΑΠΘ - 4ο εξάμηνο1 Ανάλυση Αλγορίθμων b Θέματα: Ορθότητα Χρονική αποδοτικότητα Χωρική αποδοτικότητα Βελτιστότητα b Προσεγγίσεις:
Λίστες παράλειψης (skip lists) TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A
ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Copy Constructor Deep and Shallow Copies.
Γράφημα TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A A A Συνδυαστικό αντικείμενο που αποτελείται από.
Μέγιστη ροή TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A AA A A Συνάρτηση χωρητικότητας Κατευθυνόμενο γράφημα.
Ασυμπτωτικός Συμβολισμός
Δομές Δεδομένων 1 Θέματα Απόδοσης. Δομές Δεδομένων 2 Οργανώνοντας τα Δεδομένα  Η επιλογή της δομής δεδομένων και του αλγορίθμου επηρεάζουν το χρόνο εκτέλεσης.
Ελαφρύτατες διαδρομές TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A AA A A.
Μέγιστη ροή TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A AA A A Συνάρτηση χωρητικότητας Κατευθυνόμενο γράφημα.
Συνδετικότητα γραφήματος (graph connectivity). α β Υπάρχει μονοπάτι μεταξύ α και β; Παραδείγματα: υπολογιστές ενός δικτύου ιστοσελίδες ισοδύναμες μεταβλητές.
Γράφημα Συνδυαστικό αντικείμενο που αποτελείται από 2 σύνολα:
Δομές Δεδομένων 2η Διάλεξη Αλγόριθμοι Ένωσης-Εύρεσης (Union-Find)
Μέγιστη ροή Κατευθυνόμενο γράφημα 12 Συνάρτηση χωρητικότητας
Πίνακες Συμβόλων TexPoint fonts used in EMF.
Μέγιστη ροή Κατευθυνόμενο γράφημα 12 Συνάρτηση χωρητικότητας
Ισορροπημένα Δένδρα Μπορούμε να επιτύχουμε χρόνο εκτέλεσης
Δένδρα Αναζήτησης Πολλαπλής Διακλάδωσης
Ισορροπημένα Δένδρα Μπορούμε να επιτύχουμε χρόνο εκτέλεσης
Ισορροπημένα Δένδρα Μπορούμε να επιτύχουμε χρόνο εκτέλεσης
Ουρά Προτεραιότητας (priority queue)
Δομές Αναζήτησης Χειριζόμαστε ένα σύνολο στοιχείων όπου το κάθε στοιχείο έχει ένα κλειδί από ολικά διατεταγμένο σύνολο Θέλουμε να υποστηρίξουμε δύο.
Ελαφρύτατες διαδρομές
Εξωτερική Αναζήτηση Ιεραρχία Μνήμης Υπολογιστή Εξωτερική Μνήμη
Μεταγράφημα παρουσίασης:

Ανάλυση αλγορίθμων Παράμετροι απόδοσης ενός αλγόριθμου: Χρόνος εκτέλεσης Απαιτούμενοι πόροι, π.χ. μνήμη, επικοινωνία (π.χ. σε κατανεμημένα συστήματα) Προσπάθεια υλοποίησης TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: A A A Ανάλυση της απόδοσης Θεωρητική ανάλυση Πειραματική ανάλυση

Ανάλυση αλγορίθμων TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: A A A Ανάλυση της απόδοσης Θεωρητική ανάλυση Πειραματική ανάλυση Πότε μπορούμε να είμαστε ευχαριστημένοι από την απόδοση ενός αλγόριθμου; Παράμετροι απόδοσης ενός αλγόριθμου: Χρόνος εκτέλεσης Απαιτούμενοι πόροι, π.χ. μνήμη, επικοινωνία (π.χ. σε κατανεμημένα συστήματα) Προσπάθεια υλοποίησης

Ανάλυση αλγορίθμων Χρόνος εκτέλεσης: Αναμενόμενη περίπτωση - απαιτεί γνώση της κατανομής εισόδου - όταν η κατανομή δεν είναι γνωστή (κάτι που συμβαίνει συχνά!), συνήθως υποθέτουμε ομοιόμορφη κατανομή - πιθανοκρατικοί αλγόριθμοι διαμορφώνουν την κατανομή εισόδου Χειρότερη περίπτωση - ισχύει για κάθε είσοδο - κοντά στην αναμενόμενη όταν συμβαίνει συχνά, αλλά μπορεί να είναι απαισιόδοξη όταν συμβαίνει σπάνια

Ανάλυση αλγορίθμων Πειραματική ανάλυση του χρόνου εκτέλεσης public static void main() { long startTime = System.currentTimeMillis(); // run algorithm... long endTime = System.currentTimeMillis(); long totalTime = endTime - startTime; }

Ανάλυση αλγορίθμων Πειραματική ανάλυση του χρόνου εκτέλεσης Χρόνοι εκτέλεσης σε δευτερόλεπτα για διάφορες δομές εύρεσης-ένωσης με είσοδο τυχαίο αρχείο με κόμβους και ακμές βασική δομή γρήγορης ένωσης δομή γρήγορης ένωσης με στάθμιση δομή γρήγορης ένωσης με στάθμιση και συμπίεση διαδρομής

Ασυμπτωτική ανάλυση z = 0; for (i=0; i<n; i++) { t = x[i]*y[i]; z = z+t; } Παράδειγμα: Υπολογισμός εσωτερικού γινομένου Πόσος χρόνος απαιτείται ανά εντολή; Ποια είναι η συχνότητα εκτέλεσης της κάθε εντολής; Είναι η μελέτη του ρυθμού αύξησης του χρόνου εκτέλεσης (ή άλλης παραμέτρου απόδοσης) ως συνάρτηση του μεγέθους της εισόδου

Ασυμπτωτική ανάλυση Είναι η μελέτη του ρυθμού αύξησης του χρόνου εκτέλεσης (ή άλλης παραμέτρου απόδοσης) ως συνάρτηση του μεγέθους της εισόδου z = 0; for (i=0; i<n; i++) { t = x[i]*y[i]; z = z+t; } Παράδειγμα: Υπολογισμός εσωτερικού γινομένου Χρόνος εκτέλεσης:

Ασυμπτωτική ανάλυση Παράδειγμα: Υπολογισμός εσωτερικού γινομένου Χρόνος εκτέλεσης: z = 0; for (i=0; i<n; i++) { t = x[i]*y[i]; z = z+t; } Είναι η μελέτη του ρυθμού αύξησης του χρόνου εκτέλεσης (ή άλλης παραμέτρου απόδοσης) ως συνάρτηση του μεγέθους της εισόδου

Ασυμπτωτική ανάλυση Παράδειγμα: Υπολογισμός εσωτερικού γινομένου Χρόνος εκτέλεσης: z = 0; for (i=0; i<n; i++) { t = x[i]*y[i]; z = z+t; } Είναι η μελέτη του ρυθμού αύξησης του χρόνου εκτέλεσης (ή άλλης παραμέτρου απόδοσης) ως συνάρτηση του μεγέθους της εισόδου

Ασυμπτωτική ανάλυση Παράδειγμα: Υπολογισμός εσωτερικού γινομένου Χρόνος εκτέλεσης: z = 0; for (i=0; i<n; i++) { t = x[i]*y[i]; z = z+t; } Είναι η μελέτη του ρυθμού αύξησης του χρόνου εκτέλεσης (ή άλλης παραμέτρου απόδοσης) ως συνάρτηση του μεγέθους της εισόδου

Ασυμπτωτική ανάλυση Παράδειγμα: Υπολογισμός εσωτερικού γινομένου Χρόνος εκτέλεσης: z = 0; for (i=0; i<n; i++) { t = x[i]*y[i]; z = z+t; } Είναι η μελέτη του ρυθμού αύξησης του χρόνου εκτέλεσης (ή άλλης παραμέτρου απόδοσης) ως συνάρτηση του μεγέθους της εισόδου

Ασυμπτωτική ανάλυση Παράδειγμα: Υπολογισμός εσωτερικού γινομένου Χρόνος εκτέλεσης: ασυμτωτικά γραμμική z = 0; for (i=0; i<n; i++) { t = x[i]*y[i]; z = z+t; } Είναι η μελέτη του ρυθμού αύξησης του χρόνου εκτέλεσης (ή άλλης παραμέτρου απόδοσης) ως συνάρτηση του μεγέθους της εισόδου

Ασυμπτωτική ανάλυση Παράδειγμα: Υπολογισμός εσωτερικού γινομένου Χρόνος εκτέλεσης: Θέλουμε να εξαλείψουμε τις επουσιώδεις λεπτομέρειες z = 0; for (i=0; i<n; i++) { t = x[i]*y[i]; z = z+t; } ασυμτωτικά γραμμική Είναι η μελέτη του ρυθμού αύξησης του χρόνου εκτέλεσης (ή άλλης παραμέτρου απόδοσης) ως συνάρτηση του μεγέθους της εισόδου

Ασυμπτωτική ανάλυση Εξετάζουμε τη συμπεριφορά των συναρτήσεων όσο αυξάνει το μέγεθος της εισόδου

Ασυμπτωτική ανάλυση Συμβολισμός Θ ασυμτωτικά αυστηρό φράγμα : Υπάρχουν θετικές σταθερές και τέτοιες ώστε για κάθε

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

Ασυμπτωτική ανάλυση Συμβολισμός Θ ασυμτωτικά αυστηρό φράγμα Παράδειγμα 1: (Σ) για κάθε. για κάθε Πρέπει να βρούμε θετικές σταθερές και, τέτοιες ώστε : Υπάρχουν θετικές σταθερές και τέτοιες ώστε

Ασυμπτωτική ανάλυση Θέλουμε που ισχύει όταν και Επίσης θέλουμε Έχουμε Επιλέγονταςέχουμε Άρα για καιικανοποιείται η συνθήκη (Σ). Συμβολισμός Θ ασυμτωτικά αυστηρό φράγμα Παράδειγμα 1: (Σ) για κάθε. για κάθε Πρέπει να βρούμε θετικές σταθερές και, τέτοιες ώστε : Υπάρχουν θετικές σταθερές και τέτοιες ώστε

Ασυμπτωτική ανάλυση Συμβολισμός Θ ασυμτωτικά αυστηρό φράγμα Παράδειγμα 2: Έστω ότι Τότε υπάρχουν θετικές σταθερές και με για κάθε. Δηλαδή για κάθε. Αυτό είναι αδύνατο για σταθερό. για κάθε : Υπάρχουν θετικές σταθερές και τέτοιες ώστε

Ασυμπτωτική ανάλυση static public int countTriples(int[] a, int N){ int count=0; for (int i=0; i<N; i++) for (int j=i+1; j<N; j++) for (int k=j+1; k<N; k++) if ( a[i]+a[j]+a[k] == 0) count++; return count; } Δοκιμάζει όλες τις τριάδες με Παράδειγμα: Η παρακάτω συνάρτηση εξετάζει τον πίνακα a με Ν ακέραιους και βρίσκει πόσες τριάδες δίνουν άθροισμα μηδέν

Ασυμπτωτική ανάλυση Δοκιμάζει όλες τις τριάδες με τριάδες χρόνος εκτέλεσης Παράδειγμα: Η παρακάτω συνάρτηση εξετάζει τον πίνακα a με Ν ακέραιους και βρίσκει πόσες τριάδες δίνουν άθροισμα μηδέν static public int countTriples(int[] a, int N){ int count=0; for (int i=0; i<N; i++) for (int j=i+1; j<N; j++) for (int k=j+1; k<N; k++) if ( a[i]+a[j]+a[k] == 0) count++; return count; }

Ασυμπτωτική ανάλυση Συμβολισμός O ασυμτωτικό άνω φράγμα : Υπάρχουν θετικές σταθερές και τέτοιες ώστε για κάθε

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

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

Ασυμπτωτική ανάλυση Συμβολισμός O ασυμτωτικό άνω φράγμα για κάθε : Υπάρχουν θετικές σταθερές και τέτοιες ώστε Έστω ότι για τις συναρτήσεις και υπάρχει το όριο και έχει τιμή για κάποια σταθερά Τότε

Ασυμπτωτική ανάλυση Συμβολισμός O ασυμτωτικό άνω φράγμα για κάθε : Υπάρχουν θετικές σταθερές και τέτοιες ώστε Παράδειγμα επειδή Έστω ότι για τις συναρτήσεις και υπάρχει το όριο και έχει τιμή για κάποια σταθερά Τότε

Ασυμπτωτική ανάλυση Συμβολισμός O ασυμτωτικό άνω φράγμα για κάθε : Υπάρχουν θετικές σταθερές και τέτοιες ώστε Παράδειγμα επειδή Έστω ότι για τις συναρτήσεις και υπάρχει το όριο και έχει τιμή για κάποια σταθερά Τότε

Ασυμπτωτική ανάλυση Συμβολισμός Ω ασυμτωτικό κάτω φράγμα : Υπάρχουν θετικές σταθερές και τέτοιες ώστε για κάθε

Ασυμπτωτική ανάλυση Συμβολισμός Ω ασυμτωτικό κάτω φράγμα : Υπάρχουν θετικές σταθερές και τέτοιες ώστε για κάθε Έστω ότι για τις συναρτήσεις και υπάρχει το όριο και έχει τιμή για κάποια σταθερά Τότε Ισχύει

Ασυμπτωτική ανάλυση Συμβολισμός Ω ασυμτωτικό κάτω φράγμα : Υπάρχουν θετικές σταθερές και τέτοιες ώστε για κάθε Παράδειγμα επειδή Έστω ότι για τις συναρτήσεις και υπάρχει το όριο και έχει τιμή για κάποια σταθερά Τότε

Ασυμπτωτική ανάλυση Συμβολισμός Ω ασυμτωτικό κάτω φράγμα : Υπάρχουν θετικές σταθερές και τέτοιες ώστε για κάθε Έστω ότι για τις συναρτήσεις και υπάρχει το όριο και έχει τιμή για κάποια σταθερά Τότε Παράδειγμα επειδή

Ασυμπτωτική ανάλυση Συμβολισμός Θ ασυμτωτικά αυστηρό φράγμα : Υπάρχουν θετικές σταθερές και τέτοιες ώστε για κάθε

Ασυμπτωτική ανάλυση Συμβολισμός Θ ασυμτωτικά αυστηρό φράγμα : Υπάρχουν θετικές σταθερές και τέτοιες ώστε για κάθε Ισχύει αν και μόνο αν και Έστω ότι για τις συναρτήσεις και υπάρχουν τα όρια, όπου και για κάποια σταθερά. Τότε

Ασυμπτωτική ανάλυση Συμβολισμός o ασυμτωτικά μη αυστηρό άνω φράγμα Παράδειγμα: αλλά : Για οποιαδήποτε σταθερά, υπάρχει σταθερά για κάθε τέτοια ώστε Έστω ότι για τις συναρτήσεις και υπάρχει το όριο όπου. Τότε

Ασυμπτωτική ανάλυση Συμβολισμός ω ασυμτωτικά μη αυστηρό κάτω φράγμα τέτοια ώστε Παράδειγμα: αλλά Ισχύει : Για οποιαδήποτε σταθερά, υπάρχει σταθερά για κάθε Έστω ότι για τις συναρτήσεις και υπάρχει το όριο όπου. Τότε

Ασυμπτωτική ανάλυση Προσοχή! Ακόμα και δύο γνησίως αύξουσες συναρτήσεις μπορεί να έχουν πολλά σημεία τομής

Ασυμπτωτική ανάλυση Προσοχή! Δεν είναι όλες οι συναρτήσεις ασυμπτωτικά συγκρίσιμες π.χ.,και

Ασυμπτωτική ανάλυση Ιδιότητες Μεταβατικότητα: και Αυτοπάθεια: Συμμετρία: όταν και μόνο όταν

Ασυμπτωτική ανάλυση Ιδιότητες Μεταβατικότητα και αυτοπάθεια ισχύουν και για τους συμβολισμούς Ο, Ω, ο και ω. Στη θέση της συμμετρίας έχουμε: όταν και μόνο όταν Μεταβατικότητα: και Αυτοπάθεια: Συμμετρία: όταν και μόνο όταν

Ασυμπτωτική ανάλυση Παραδείγματα Θέλουμε να διατάξουμε τις παρακάτω συναρτήσεις ως προς το ρυθμό αύξησης, από τη μικρότερη ως τη μεγαλύτερη

Ασυμπτωτική ανάλυση Παραδείγματα Θέλουμε να διατάξουμε τις παρακάτω συναρτήσεις ως προς το ρυθμό αύξησης, από τη μικρότερη ως τη μεγαλύτερη ΈχουμεΓια και Γενικά Διάταξη

Ασυμπτωτική ανάλυση Παραδείγματα Θέλουμε να διατάξουμε τις παρακάτω συναρτήσεις ως προς το ρυθμό αύξησης, από τη μικρότερη ως τη μεγαλύτερη Έχουμε Για Έχουμε Διάταξη

Ασυμπτωτική ανάλυση Παραδείγματα Θέλουμε να διατάξουμε τις παρακάτω συναρτήσεις ως προς το ρυθμό αύξησης, από τη μικρότερη ως τη μεγαλύτερη Έχουμε Για Έχουμε Διάταξη

Ασυμπτωτική ανάλυση Παραδείγματα Θέλουμε να διατάξουμε τις παρακάτω συναρτήσεις ως προς το ρυθμό αύξησης, από τη μικρότερη ως τη μεγαλύτερη Έχουμε Για Έχουμε Διάταξη

Ασυμπτωτική ανάλυση Παραδείγματα Θέλουμε να διατάξουμε τις παρακάτω συναρτήσεις ως προς το ρυθμό αύξησης, από τη μικρότερη ως τη μεγαλύτερη Έχουμε Για Έχουμε Διάταξη

Ασυμπτωτική ανάλυση Παραδείγματα Θέλουμε να διατάξουμε τις παρακάτω συναρτήσεις ως προς το ρυθμό αύξησης, από τη μικρότερη ως τη μεγαλύτερη Επομένως έχουμε

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

Ασυμπτωτική ανάλυση λογαριθμική κλίμακα Πρακτικές πολυπλοκότητες

Ασυμπτωτική ανάλυση Χρήσιμες συναρτήσεις στην ανάλυση αλγορίθμων κάτω ακέραιο μέρος : μεγαλύτερος ακέραιος άνω ακέραιο μέρος : μικρότερος ακέραιος φυσικός λογάριθμος : τέτοιο ώστε δυαδικός λογάριθμος : τέτοιο ώστε ακέραιος δυαδικός λογάριθμος : (αριθμός δυαδικών ψηφίων στη δυαδική αναπαράσταση του ) - 1 Ν-οστός αρμονικός αριθμός

Ασυμπτωτική ανάλυση Χρήσιμες συναρτήσεις στην ανάλυση αλγορίθμων διωνυμικοί συντελεστές για μικρή σταθερά Προσέγγιση Stirling Γεωμετρικό άθροισμα

Παράδειγμα: Δυαδική Αναζήτηση Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε

Παράδειγμα: Δυαδική Αναζήτηση θέση στοιχείο Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε

Παράδειγμα: Δυαδική Αναζήτηση θέση στοιχείο θέση μέσου στοιχείου = (15+1)/2 = 8 v =111 α 8 = 56 < v Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε

Παράδειγμα: Δυαδική Αναζήτηση θέση στοιχείο θέση μέσου στοιχείου = (15+1)/2 = 8 v =111 α 8 = 56 < v Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε

Παράδειγμα: Δυαδική Αναζήτηση θέση στοιχείο θέση μέσου στοιχείου = (9+15)/2 = 12 v =111 α 12 = 128 > v Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε

Παράδειγμα: Δυαδική Αναζήτηση θέση στοιχείο θέση μέσου στοιχείου = (9+15)/2 = 12 v =111 α 12 = 128 > v Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε

Παράδειγμα: Δυαδική Αναζήτηση θέση στοιχείο θέση μέσου στοιχείου = (9+11)/2 = 10 v =111 α 10 = 90 < v Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε

Παράδειγμα: Δυαδική Αναζήτηση θέση στοιχείο θέση μέσου στοιχείου = (9+11)/2 = 10 v =111 α 10 = 90 < v Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε

Παράδειγμα: Δυαδική Αναζήτηση θέση στοιχείο θέση μέσου στοιχείου = (11+11)/2 = 11 v =111 α 11 = 102 < v Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε

Παράδειγμα: Δυαδική Αναζήτηση θέση στοιχείο θέση μέσου στοιχείου = (11+11)/2 = 11 v =111 α 11 = 102 < v Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε

Παράδειγμα: Δυαδική Αναζήτηση θέση στοιχείο Το v δεν υπάρχει στην ακολουθία. Βρήκαμε όμως το αμέσως μικρότερο στοιχείο. Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε

Παράδειγμα: Δυαδική Αναζήτηση Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε public static int binarySearch(int a[], int v, int l, int r) {while (r>=l) {int m=(l+r)/2; if (v==a[m]) return m; if (v<a[m]) r=m-1; else l=m+1;} return -1;}

Παράδειγμα: Δυαδική Αναζήτηση Ανάλυση: Έστω Τ(n) ο χρόνος της αναζήτησης σε ακολουθία n στοιχείων. Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε

Παράδειγμα: Δυαδική Αναζήτηση Ανάλυση: Έστω Τ(n) ο χρόνος της αναζήτησης σε ακολουθία n στοιχείων. Ισχύει Δυαδική αναζήτηση: προϋποθέτει να έχει γίνει ταξινόμηση της ακολουθίας δηλαδή Κάθε βήμα είτε βρίσκει το v είτε αποκλείει τα μισά σχεδόν στοιχεία της ακολουθίας που απομένουν. Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε χειρότερη περίπτωση

Αναζήτηση Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε ένα τέτοιο ώστε Χρόνος δυαδικής αναζήτησης = Με πίνακες διασποράς επιτυγχάνουμε χρόνο. (Προσεχώς σε μερικές εβδομάδες...)

Αναζήτηση Μας δίνεται μία ακολουθία από n ακέραιους και ένας ακέραιος Θέλουμε να βρούμε τον μεγαλύτερο τέτοιο ώστε Καλύτερος δυνατός ασυμπτωτικός χρόνος όταν βασιζόμαστε μόνο σε πράξεις σύγκρισης (>,<,=). Χρόνος δυαδικής αναζήτησης = Εύρεση προκατόχου Με πιο περίπλοκες δομές μπορούμε να πετύχουμε χρόνο.

Αναδρομικές σχέσεις Πολύ συχνά ο χρόνος εκτέλεσης ενός αλγόριθμου μπορεί να εκφραστεί μέσω κάποιας αναδρομικής σχέσης. Παράδειγμα: Ακολουθιακή αναζήτηση και απαλοιφή ενός στοιχείου μέχρι να μείνει κενή ακολουθία.

Αναδρομικές σχέσεις Πολύ συχνά ο χρόνος εκτέλεσης ενός αλγόριθμου μπορεί να εκφραστεί μέσω κάποιας αναδρομικής σχέσης. Παράδειγμα: Ακολουθιακή αναζήτηση και απαλοιφή ενός στοιχείου μέχρι να μείνει κενή ακολουθία.

Αναδρομικές σχέσεις Πολύ συχνά ο χρόνος εκτέλεσης ενός αλγόριθμου μπορεί να εκφραστεί μέσω κάποιας αναδρομικής σχέσης. Παράδειγμα: Ακολουθιακή αναζήτηση και απαλοιφή ενός στοιχείου μέχρι να μείνει κενή ακολουθία.

Αναδρομικές σχέσεις Πολύ συχνά ο χρόνος εκτέλεσης ενός αλγόριθμου μπορεί να εκφραστεί μέσω κάποιας αναδρομικής σχέσης. Έστω Τ(n) ο χρόνος εκτέλεσης για ακολουθία n στοιχείων στη χειρότερη περίπτωση. Ισχύει Παράδειγμα: Ακολουθιακή αναζήτηση και απαλοιφή ενός στοιχείου μέχρι να μείνει κενή ακολουθία.

Αναδρομικές σχέσεις Πολύ συχνά ο χρόνος εκτέλεσης ενός αλγόριθμου μπορεί να εκφραστεί μέσω κάποιας αναδρομικής σχέσης. Έστω Τ(n) ο χρόνος εκτέλεσης για ακολουθία n στοιχείων στη χειρότερη περίπτωση. Ισχύει Με τη μέθοδο της αντικατάστασης λαμβάνουμε Παράδειγμα: Ακολουθιακή αναζήτηση και απαλοιφή ενός στοιχείου μέχρι να μείνει κενή ακολουθία.

Αναδρομικές σχέσεις Έστω Τ(n) ο χρόνος εκτέλεσης για ακολουθία n στοιχείων στη χειρότερη περίπτωση. Ισχύει Με τη μέθοδο της αντικατάστασης λαμβάνουμε Παράδειγμα: Ακολουθιακή αναζήτηση και απαλοιφή ενός στοιχείου μέχρι να μείνει κενή ακολουθία.

Αναδρομικές σχέσεις Έστω Τ(n) ο χρόνος εκτέλεσης για ακολουθία n στοιχείων στη χειρότερη περίπτωση. Ισχύει Με επαγωγή: Θέλουμε να δείξουμε ότι δηλαδή ότι για κάποια θετική σταθερά c. Η βάση της επαγωγής είναι που ισχύει για Επαγωγικό βήμα: Έστω Έχουμε Παράδειγμα: Ακολουθιακή αναζήτηση και απαλοιφή ενός στοιχείου μέχρι να μείνει κενή ακολουθία.

Αναδρομικές σχέσεις Έστω Τ(n) ο χρόνος εκτέλεσης για ακολουθία n στοιχείων στη χειρότερη περίπτωση. Ισχύει Με επαγωγή: Επίσης ισχύει. Θα δείξουμε επαγωγικά ότι για κάποια θετική σταθερά c’. Η βάση της επαγωγής είναι που ισχύει για Επαγωγικό βήμα: Έστω Έχουμε που ισχύει για Παράδειγμα: Ακολουθιακή αναζήτηση και απαλοιφή ενός στοιχείου μέχρι να μείνει κενή ακολουθία.

Αναδρομικές σχέσεις Έστω Τ(n) ο χρόνος εκτέλεσης για ακολουθία n στοιχείων στη χειρότερη περίπτωση. Ισχύει Άρα έχουμεκαι Παράδειγμα: Ακολουθιακή αναζήτηση και απαλοιφή ενός στοιχείου μέχρι να μείνει κενή ακολουθία.

Αναδρομικές σχέσεις Παράδειγμα: Με τη μέθοδο της αντικατάστασης λαμβάνουμε

Αναδρομικές σχέσεις Παράδειγμα: Με τη μέθοδο της αντικατάστασης λαμβάνουμε

Αναδρομικές σχέσεις Παράδειγμα: Εναλλακτικά έχουμε: Τότε Άρα οπότε