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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Quicksort [Hoare, 62] Αλγόριθµοι & Πολυπλοκότητα (Χειµώνας 2011) Quicksort 1

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

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

Διάλεξη 19: Αλγόριθμοι ΤαξινόμησηςII. Διδάσκων: Παναγιώτης Ανδρέου

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

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

ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΑΝΑΛΥΣΗ ΑΛΓΟΡΙΘΜΩΝ

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

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

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

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

Διδάσκων: Κωνσταντίνος Κώστα Διαφάνειες: Δημήτρης Ζεϊναλιπούρ ΕΠΛ 035 Δομές Δεδομένων και Αλγόριθμοι για Ηλ. Μηχ. και Μηχ. Υπολ.

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

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

ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΑΝΑΛΥΣΗ ΑΛΓΟΡΙΘΜΩΝ

Ταξινόμηση με συγχώνευση Merge Sort

Διάλεξη 04: Παραδείγματα Ανάλυσης

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

Διάλεξη 04: Παραδείγματα Ανάλυσης Πολυπλοκότητας/Ανάλυση Αναδρομικών Αλγόριθμων

ΕΠΛ231 Δομές Δεδομένων και Αλγόριθμοι 4. Παραδείγματα Ανάλυσης Πολυπλοκότητας Ανάλυση Αναδρομικών Αλγόριθμων

Εργαστήριο 6: Αναζήτηση, Ανάλυση Πολυπλοκότητας

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

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

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

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

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

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

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

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

Αλγόριθµοι Divide-and- Conquer

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

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

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

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

Εισαγωγή στην Ανάλυση Αλγορίθμων (2-3)

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

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

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

Σχεδίαση Αλγορίθμων -Τμήμα Πληροφορικής ΑΠΘ - Εξάμηνο 4ο

Ταξινόμηση. Παύλος Εφραιμίδης. Δομές Δεδομένων Ταξινόμηση 1

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

ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΑΝΑΛΥΣΗ ΑΛΓΟΡΙΘΜΩΝ

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

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

auth Αλγόριθμοι - Τμήμα Πληροφορικής ΑΠΘ - Εξάμηνο 4ο

Προχωρημένες έννοιες προγραμματισμού σε C

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

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

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

Τεχνικές Σχεδιασμού Αλγορίθμων

Στοιχεία Αλγορίθµων και Πολυπλοκότητας

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

a 1 a 2 a n. 3. i = j 1 5. A[i + 1] = A[i] 6. i = i 1

Αναδρομή Ανάλυση Αλγορίθμων

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

Αλγοριθμικές Τεχνικές. Brute Force. Διαίρει και Βασίλευε. Παράδειγμα MergeSort. Παράδειγμα. Τεχνικές Σχεδιασμού Αλγορίθμων

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

1η Σειρά Γραπτών Ασκήσεων

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

Πολλαπλασιασμός: αλγόριθμος

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

Αριθμοθεωρητικοί Αλγόριθμοι

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

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

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

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

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

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

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

για NP-Δύσκολα Προβλήματα

Περιεχόμενα. Εισαγωγή του επιμελητή, Γιάννης Σταματίου 15 Πρόλογος 17 Εισαγωγή 23. Μέρος I. ΕΠΑΝΑΛΗΠΤΙΚΟΙ ΑΛΓΟΡΙΘΜΟΙ ΚΑΙ ΑΝΑΛΛΟΙΩΤΕΣ ΣΥΝΘΗΚΕΣ

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

Ανάλυση Αλγορίθµων. Σύντοµη επανάληψη (ΕΠΛ 035).

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

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

ιακριτές Μέθοδοι για την Επιστήμη των Υπολογιστών

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

Πανεπιστήμιο Ιωαννίνων Τμήμα Πληροφορικής Δομές Δεδομένων [ΠΛΥ302] Χειμερινό Εξάμηνο 2012

Αλγοριθμικές Τεχνικές

1o Φροντιστήριο ΗΥ240

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

ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΑΝΑΛΥΣΗ ΑΛΓΟΡΙΘΜΩΝ

Δομές Δεδομένων Ενότητα 2

οµές εδοµένων 3 ο Εξάµηνο Τµήµα Πανεπιστήµιο Πληροφορικής Ιωαννίνων ΟΜΕΣ Ε ΟΜΕΝΩΝ

Υπολογιστικά & Διακριτά Μαθηματικά

Transcript:

Διαίρει-και-Βασίλευε Διδάσκοντες: Σ. Ζάχος, Δ. Φωτάκης Επιμέλεια διαφανειών: Δ. Φωτάκης Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Εθνικό Μετσόβιο Πολυτεχνείο Διαίρει-και-Βασίλευε Γενική μέθοδος σχεδιασμού αλγορίθμων: Διαίρεση σε ( 2) υποπροβλήματα (σημαντικά) μικρότερου μεγέθους. Ανεξάρτητη επίλυση υπο-προβλημάτων (αναδρομικά) (για μικρά υποπροβλήματα εφαρμόζονται στοιχειώδεις αλγόριθμοι). Σύνθεση λύσης αρχικού προβλήματος από λύσεις υποπροβλημάτων. Ισχυρή μέθοδος, με πολλές σημαντικές εφαρμογές! Ταξινόμηση Επιλογή: MergeSort, QuickSort, QuickSelect. Πολλαπλασιασμός αριθμών, πινάκων, FFT. «Εκλέπτυνση»: Δυαδική αναζήτηση, ύψωση σε δύναμη. (Εύκολη) ανάλυση με αναδρομικές σχέσεις. Μη γραμμικές, συγκεκριμένης μορφής. Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 2 MergeSort Πρόβλημα Ταξινόμησης: Είσοδος : ακολουθία n αριθμών (α 1, α 2,..., α n ). Έξοδος : μετάθεση (α 1, α 2,..., α n ) με αριθμούς σε αύξουσα σειρά ( i α i α i+1 ). MergeSort (ταξινόμηση με συγχώνευση): Διαίρεση ακολουθίας εισόδου (n στοιχεία) σε δύο υπο-ακολουθίες ίδιου μήκους (n / 2 στοιχεία). Ταξινόμηση υπο-ακολουθιών αναδρομικά. Συγχώνευση (merge) δύο ταξινομημένων υπο-ακολουθιών σε μία ταξινομημένη ακολουθία. MergeSort(int A[], int left, int right) { if (left >= right) return; mid = (left + right) / 2; mergesort(a, left, mid); mergesort(a, mid+1, right); merge(a, left, mid, right); } Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) 3 MergeSort Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 4

Συγχώνευση Merge Συγχώνευση ταξινομημένων Α[left...mid] και A[mid+1...right] σε ταξινομημένο A[left...right]. 7 5 8 6 4 3 3 4 5 6 7 8 Συγχώνευση ταξινομημένων Α[left...mid] και A[mid+1...right] σε ταξινομημένο A[left...right]. X[right left+1] A[left...right]; // προσωρινή αποθήκευση i : 0 <= i <= xmid // δείκτης αριστερό τμήμα j : xmid+1 <= j <= xright // δείκτης δεξιό τμήμα k : left <= k <= right // δείκτης στον συγχωνευμένο πίνακα Χ[i] : μικρότερο διαθέσιμο στοιχείο στο αριστερό τμήμα. Χ[j] : μικρότερο διαθέσιμο στοιχείο στο δεξιό τμήμα. while ((i <= xmid) && (j <= xright)) if (X[i] <= X[j]) A[k++] = X[i++]; else A[k++] =X[j++]; Όταν ένα τμήμα εξαντληθεί, αντιγράφουμε όλα τα στοιχεία του άλλου στο Α[]. Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 5 Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 6 Ορθότητα Ορθότητα merge επειδή τα τμήματα είναι ταξινομημένα. Όταν ένα στοιχείο μεταφέρεται στον Α[], δεν υπάρχει μικρότερο διαθέσιμο στοιχείο στα δύο τμήματα. Ορθότητα mergesort αποδεικνύεται επαγωγικά : Βάση (ένα στοιχείο) τετριμμένη. Δύο τμήματα σωστά ταξινομημένα (επαγωγική υποθ.) και συγχωνεύονται σωστά (ορθότητα merge) Σωστά ταξινομημένος πίνακας Α[]. Χρόνος Εκτέλεσης Χρόνος εκτέλεσης merge (για n στοιχεία) : Θ(n) (γραμμικός) Θ(1) λειτουργίες για κάθε στοιχείο. Χρόνος εκτέλεσης αλγόριθμων «διαίρει-και-βασίλευε» με διατύπωση και λύση αναδρομικής εξίσωσης λειτουργίας. Τ(n) : χρόνος (χ.π.) για ταξινόμηση n στοιχείων. T(n /2): ταξινόμηση αριστερού τμήματος (n /2 στοιχεία). T(n /2): ταξινόμηση δεξιού τμήματος (n /2 στοιχεία). Θ(n) : συγχώνευση ταξινομημένων τμημάτων. T(n) = 2 T(n /2) + Θ(n), T(1) = Θ(1) Χρόνος εκτέλεσης ΜergeSort: T(n) =??? Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 7 Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 8

Δέντρο Αναδρομής Master Theorem T(n) = 2 T(n /2) + Θ(n), Τ(1) = Θ(1) Δέντρο αναδρομής : Ύψος : Θ(log n) #κορυφών : Θ(n) Ανάλυση χρόνου εκτέλεσης αλγορίθμων «διαίρει-και-βασίλευε» με αναδρομικές σχέσεις της μορφής όπου α, b σταθερές και f(n) θετική συνάρτηση. Επίλυση με Θεώρημα Κυρίαρχου Όρου (Master Theorem) Χρόνος / επίπεδο : Θ(n) Συνολικός χρόνος : Θ(n log n). Ασυμπτωτικά μεγαλύτερος από f(n) και καθορίζει λύση. Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 9 Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 10 Master Theorem: Ειδικές Μορφές Παραδείγματα Όταν f(n) = Θ(n), δηλ. Αν με γ 1 + γ 2 < 1, τότε Όταν f(n) = Θ(n d ), δηλ. Τ(n) = 9 T(n/3) + n. Τ(n) = T(2n/3) + 1. Τ(n) = 3 T(n/4) + nlogn. Τ(n) = 2 T(n/2) + n. Τ(n) = 2 T(n/2) + nlogn. Δεν εμπίπτει! Με δέντρο αναδρομής βρίσκουμε ότι T(n) = Θ(nlog 2 n). Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 11 Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 12

Πολλαπλασιασμός Αριθμών Πολλαπλασιασμός Αριθμών Υπολογισμός αθροίσματος x+y, x και y αριθμοί n-bits. Κλασσικός αλγόριθμος πρόσθεσης, χρόνος Θ(n). Υπολογισμός γινομένου x y, x και y αριθμοί με n-bits. Κλασσικός αλγόριθμος πολ/μού, χρόνος Θ(n 2 ). Καλύτερος αλγόριθμος; Διαίρει-και-Βασίλευε: Διαίρεση: Όμως z m υπολογίζεται με 1 μόνο πολ/μο (n/2+1)-bits. 3 πολλαπλασιασμοί (n / 2)-bits, 2 ολισθήσεις, 6 προσθέσεις. Παράδειγμα: 2576 7935 = 20440560 4 πολλαπλασιασμοί (n / 2)-bits, 2 ολισθήσεις, 3 προσθέσεις. Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 13 Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 14 Πολλαπλασιασμός Πινάκων Αλγόριθμος Strassen (1969) Υπολογισμός γινομένου C = A B. A, B τετραγωνικοί πίνακες n n. Εφαρμογή ορισμού: Χρόνος Θ(n 3 ) (n 2 στοιχεία, χρόνος Θ(n) για καθένα). Διαίρει-και-Βασίλευε: 8 πολ/μοι και 4 προσθέσεις πινάκων 7 πολ/μοι και 24 προσθέσεις πινάκων Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 15 Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 16

Υπολογισμός Δύναμης (Diffie-Hellman) Συμφωνία Αλίκης και Βασίλη σε κρυπτογραφικό κλειδί. Εύα παρακολουθεί για να «κλέψει» το κλειδί. Α, Β συμφωνούν δημόσια σε πρώτο p και ακέραιο q < p. Ε γνωρίζει p, q. Εμπλεκόμενοι αριθμοί είναι πολυψήφιοι (π.χ. 512 ψηφία). Α διαλέγει τυχαία και υπολογίζει Β διαλέγει τυχαία και υπολογίζει Α, Β ανταλλάσσουν q α, q b και τα μαθαίνει Ε. Α, B υπολογίζουν Κ (μόνοι τους). ΕδενξέρειΚ. Υπολογισμός Δύναμης Εφαρμογή υποθέτει αποδοτικό αλγόριθμο υπολογισμού, x, n, p πολυψήφιοι ακέραιοι. Υπολογισμός δυνάμεων με τη σειρά (1, 2, 3, ): αν μήκος 512 bits, χρειάζεται περίπου 2 512 πολ/μους!!! Διαίρει-και-Βασίλευε (έστω n δύναμη του 2): Υπολογίζουμε αναδρομικά και #πολλαπλασιασμών: Για Κ, Ε χρειάζεταια, b (δεν μεταδόθηκαν). Επίλυση διακριτού λογαρίθμου (πολύ δύσκολο). p με μήκος 512 bits: περίπου 2 10 πολ/μους. Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 17 Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 18 Προϋποθέσεις Εφαρμογής (Αντι)παράδειγμα Διαίρεση σημαντικά ευκολότερη από επίλυση αρχικού. Σύνθεση σημαντικά ευκολότερη από επίλυση αρχικού. Υπο-στιγμιότυπα σημαντικά μικρότερα από αρχικό (π.χ. αρχικό μέγεθος n, υπο-στιγμ. μεγέθους n / c, c > 1). Ανεξάρτητα υπο-στιγμιότυπα που λύνονται από ανεξάρτητες αναδρομικές κλήσεις. Ίδια ή επικαλυπτόμενα υπο-στιγμιότυπα : σημαντική και αδικαιολόγητη αύξηση χρόνου εκτέλεσης. Επικαλυπτόμενα υπο-στιγμιότυπα : Δυναμικός Προγραμματισμός Υπολογισμός n-οστού όρου ακολουθίας Fibonacci. long fibrec(long n) { if (n <= 1) return(n); return(fibrec(n-1) + fibrec(n-2)); } Χρόνος εκτέλεσης: Λύση: Επικαλυπτόμενα στιγμ.: Εκθετικός χρόνος! Αλγόριθμος γραμμικού χρόνου; Καλύτερος αλγόριθμος; fib(n) { int cur = 1, prev = 0; for (i = 2; i <= n; i++) { cur = cur + prev; prev = cur prev; } return(cur); } Αλγόριθμοι & Πολυπλοκότητα (Άνοιξη 2007) Διαίρει-και-Βασίλευε 19 Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 20

Ακολουθία Fibonacci Ακολουθία Fibonacci: Θεωρούμε πίνακα και Παρατηρούμε ότι Με επαγωγή αποδεικνύουμε ότι Διαίρει-και-Βασίλευε: Υπολογισμός σε χρόνο Ο(log n) (όπως με αριθμούς). Υπολογίζω αναδρομικά το και Αλγόριθμοι & Πολυπλοκότητα (Χειμώνας 2009) Διαίρει-και-Βασίλευε 21