TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός πρόβλημα μεγέθους Ν διάσπαση πρόβλημα.

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.
Πολυπλοκότητα Παράμετροι της αποδοτικότητας ενός αλγόριθμου:
Εισαγωγή στον Προγραμματισμό, Αντώνιος Συμβώνης, ΣΕΜΦΕ, ΕΜΠ, Slide 1 Εβδομάδα 9: Διανύσματα και λίστες.
Ισορροπημένα Δένδρα 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 εισαγωγή αναζήτησηεπιλογή διατεταγμένος πίνακας.
Γιάννης Σταματίου Μη αποδοτική αναδρομή και η δυναμική προσέγγιση Webcast 8.
Ψηφιακά Δένδρα 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 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 A A A Μπορούμε να επιτύχουμε χρόνο εκτέλεσης για.
ΜΑΘΗΜΑ: ΣΧΕΔΙΑΣΗ ΑΛΓΟΡΙΘΜΩΝ ΔΙΔΑΣΚΩΝ: Π. ΚΑΤΣΑΡΟΣ Κυριακή, 11 Ιανουαρίου 2015Κυριακή, 11 Ιανουαρίου 2015Κυριακή, 11 Ιανουαρίου 2015Κυριακή, 11 Ιανουαρίου.
Ψηφιακά Δένδρα 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 Δυναμικό σύνολο 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) Δομή δεδομένων που υποστηρίζει.
ΜΑΘΗΜΑ: ΣΧΕΔΙΑΣΗ ΑΛΓΟΡΙΘΜΩΝ ΔΙΔΑΣΚΩΝ: Π. ΚΑΤΣΑΡΟΣ Παρασκευή, 3 Απριλίου 2015Παρασκευή, 3 Απριλίου 2015Παρασκευή, 3 Απριλίου 2015Παρασκευή, 3 Απριλίου 2015Τμ.
Γραμμικός Προγραμματισμός 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 αβ ζ η ε γ θ Το γράφημα.
Διερεύνηση γραφήματος. Ένας αλγόριθμος διερεύνησης γραφήματος επισκέπτεται τους κόμβους του γραφήματος με μια καθορισμένη στρατηγική, π.χ. κατά εύρος.
Αλγόριθμοι - Τμήμα Πληροφορικής ΑΠΘ - 4ο εξάμηνο1 Ανάλυση Αλγορίθμων b Θέματα: Ορθότητα Χρονική αποδοτικότητα Χωρική αποδοτικότητα Βελτιστότητα b Προσεγγίσεις:
Λίστες παράλειψης (skip lists) 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 AA A A Συνάρτηση χωρητικότητας Κατευθυνόμενο γράφημα.
2/28/00epl-1311 Παραδειγματα Aλγοριθμων Αριθμος λεξεων που διαβαστηκαν απο εισοδο Εκτυπωση περιφερειας τετραγωνων με * Υπολογισμος exp(x,n) = 1 + x/1!
Ελαφρύτατες διαδρομές 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 Συνάρτηση χωρητικότητας Κατευθυνόμενο γράφημα.
Γράφημα Συνδυαστικό αντικείμενο που αποτελείται από 2 σύνολα:
Αρχιτεκτονικη & Γεωμετρια του Παρθενωνα
Μέγιστη ροή Κατευθυνόμενο γράφημα 12 Συνάρτηση χωρητικότητας
Πίνακες Συμβόλων TexPoint fonts used in EMF.
Μέγιστη ροή Κατευθυνόμενο γράφημα 12 Συνάρτηση χωρητικότητας
Δυναμικός Προγραμματισμός
Ισορροπημένα Δένδρα Μπορούμε να επιτύχουμε χρόνο εκτέλεσης
Δένδρα Αναζήτησης Πολλαπλής Διακλάδωσης
Ισορροπημένα Δένδρα Μπορούμε να επιτύχουμε χρόνο εκτέλεσης
Ισορροπημένα Δένδρα Μπορούμε να επιτύχουμε χρόνο εκτέλεσης
Ουρά Προτεραιότητας (priority queue)
Δομές Αναζήτησης Χειριζόμαστε ένα σύνολο στοιχείων όπου το κάθε στοιχείο έχει ένα κλειδί από ολικά διατεταγμένο σύνολο Θέλουμε να υποστηρίξουμε δύο.
Οικιακή Οικονομία Α’ Γυμνασίου Μάθημα 6ο. Διδάσκων καθηγητής
Ελαφρύτατες διαδρομές
Λύση προβλημάτων και Δημιουργικότητα
Εξωτερική Αναζήτηση Ιεραρχία Μνήμης Υπολογιστή Εξωτερική Μνήμη
§14. Перпендикуляр және көлбеу. §15. Үш перпендикуляр туралы теорема
Μεταγράφημα παρουσίασης:

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός πρόβλημα μεγέθους Ν διάσπαση πρόβλημα μεγέθους Ν-k πρόβλημα μεγέθους k «Διαίρει και βασίλευε» : ανεξάρτητα υποπροβλήματα

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός πρόβλημα μεγέθους Ν διάσπαση πρόβλημα μεγέθους Ν 2 πρόβλημα μεγέθους Ν 1 Σε κάποιες περιπτώσεις όμως τα υποπροβλήματα δεν είναι ανεξάρτητα Υπάρχουν επικαλυπτόμενα υποπροβλήματα, γεγονός που μπορεί να οδηγήσει σε πολύ μεγάλους χρόνους εκτέλεσης

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Παράδειγμα: Υπολογισμός της ακολουθίας Fibonacci Η επίλυση της αναδρομικής εξίσωσης δίνει

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Παράδειγμα: Υπολογισμός της ακολουθίας Fibonacci int fibonacci(int n) { if (n<1) return 0; if (n==1) return 1; return fibonacci(n-1) + fibonacci(n-2); } Μπορεί να υπολογιστεί με το ακόλουθο αναδρομικό πρόγραμμα :

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Παράδειγμα: Υπολογισμός της ακολουθίας Fibonacci Μπορεί να υπολογιστεί με το ακόλουθο αναδρομικό πρόγραμμα : Χρόνος εκτέλεσης : int fibonacci(int n) { if (n<1) return 0; if (n==1) return 1; return fibonacci(n-1) + fibonacci(n-2); }

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός int fibonacci(int n) { if (n<1) return 0; if (n==1) return 1; return fibonacci(n-1) + fibonacci(n-2); } Δένδρο αναδρομής

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Δένδρο αναδρομής Ιδέα: Αντί να υπολογίσουμε το f 4 δύο φορές, το υπολογίζουμε μία φορά και αποθηκεύουμε την τιμή του …

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Δένδρο αναδρομής Ιδέα: Αντί να υπολογίσουμε το f 4 δύο φορές, το υπολογίζουμε μία φορά και αποθηκεύουμε την τιμή του … ομοίως και για τις άλλες τιμές που χρειαζόμαστε

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Παράδειγμα: Υπολογισμός της ακολουθίας Fibonacci int fibonacci(int n) { int i; int F[n+1]; F[0]=; F[1]=1; for (int i=2; i<=n; i++) F[i] = F[i-1] + F[i-2]; return F[n]; } Μπορεί να υπολογιστεί σε γραμμικό χρόνο με το ακόλουθο πρόγραμμα :

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Συνθετικός δυναμικός προγραμματισμός (bottom-up dynamic programming) Υπολογίζει και αποθηκεύει όλες τις τιμές της συνάρτησης με τη σειρά ξεκινώντας τον υπολογισμό από τη μικρότερη τιμή του ορίσματος. int fibonacci(int n) { int i; int F[n+1]; F[0]=; F[1]=1; for (int i=2; i<=n; i++) F[i] = F[i-1] + F[i-2]; return F[n]; }

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Αναλυτικός δυναμικός προγραμματισμός (top-down dynamic programming) int fibonacci(int n) { int t; if (knownF[n] != unknown) return knownF[n]; if (n==0) t = 0; if (n==1) t = 1; if (n > 1) t = fibonacci(n-1) + fibonacci(n-2); return knownF[n] = t; } Το αναδρομικό πρόγραμμα αποθηκεύει τις τιμές που υπολογίζει και αποφεύγει τον υπολογισμό ήδη αποθηκευμένων τιμών.

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός int fibonacci(int n) { int t; if (knownF[n] != unknown) return knownF[n]; if (n==0) t = 0; if (n==1) t = 1; if (n > 1) t = fibonacci(n-1) + fibonacci(n-2); return knownF[n] = t; } Δένδρο αναδρομής

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Αναλυτικός δυναμικός προγραμματισμός (top-down dynamic programming) Το αναδρομικό πρόγραμμα αποθηκεύει τις τιμές που υπολογίζει και αποφεύγει τον υπολογισμό ήδη αποθηκευμένων τιμών. Συνθετικός δυναμικός προγραμματισμός (bottom-up dynamic programming) Υπολογίζει και αποθηκεύει όλες τις τιμές της συνάρτησης με τη σειρά ξεκινώντας τον υπολογισμό από τη μικρότερη τιμή του ορίσματος. Γενικά ο αναλυτικός δυναμικός προγραμματισμός είναι προτιμητέος επειδή: Παρέχει μηχανικό τρόπο μετασχηματισμού της λύση ενός προβλήματος Ρυθμίζει αυτόματα τη σειρά υπολογισμού των υποπροβλημάτων Αποφεύγει την επίλυση υποπροβλημάτων που δε χρειάζονται

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Το πρόβλημα του σακιδίου (knapsack problem) Έχουμε Ν τύπους αντικειμένων {1,2,…,Ν}. Το αντικείμενο k έχει μέγεθος size(k) και αξία value(k). Ο σκοπός μας είναι να γεμίσουμε με τα αντικείμενα αυτά ένα σακίδιο μεγέθους M έτσι ώστε η συνολική αξία των αντικειμένων να είναι η μέγιστη δυνατή Μ=20 size(1) = 12 value(1)= 20 size(2) = 8 value(2)= 14 size(3) = 6 value(3)= 11

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Το πρόβλημα του σακιδίου (knapsack problem) Μ=20 size(1) = 12 value(1)= 20 size(2) = 8 value(2)= 14 size(3) = 6 value(3)= size = 20 value = 34 Έχουμε Ν τύπους αντικειμένων {1,2,…,Ν}. Το αντικείμενο k έχει μέγεθος size(k) και αξία value(k). Ο σκοπός μας είναι να γεμίσουμε με τα αντικείμενα αυτά ένα σακίδιο μεγέθους M έτσι ώστε η συνολική αξία των αντικειμένων να είναι η μέγιστη δυνατή.

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Το πρόβλημα του σακιδίου (knapsack problem) Μ=20 size(1) = 12 value(1)= 20 size(2) = 8 value(2)= 14 size(3) = 6 value(3)= 11 1 size = 18 value = 31 3 Έχουμε Ν τύπους αντικειμένων {1,2,…,Ν}. Το αντικείμενο k έχει μέγεθος size(k) και αξία value(k). Ο σκοπός μας είναι να γεμίσουμε με τα αντικείμενα αυτά ένα σακίδιο μεγέθους M έτσι ώστε η συνολική αξία των αντικειμένων να είναι η μέγιστη δυνατή.

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Το πρόβλημα του σακιδίου (knapsack problem) Μ=20 size(1) = 12 value(1)= 20 size(2) = 8 value(2)= 14 size(3) = 6 value(3)= 11 size = 16 value = Έχουμε Ν τύπους αντικειμένων {1,2,…,Ν}. Το αντικείμενο k έχει μέγεθος size(k) και αξία value(k). Ο σκοπός μας είναι να γεμίσουμε με τα αντικείμενα αυτά ένα σακίδιο μεγέθους M έτσι ώστε η συνολική αξία των αντικειμένων να είναι η μέγιστη δυνατή.

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Το πρόβλημα του σακιδίου (knapsack problem) Μ=20 size(1) = 12 value(1)= 20 size(2) = 8 value(2)= 14 size(3) = 6 value(3)= 11 size = 20 value = Έχουμε Ν τύπους αντικειμένων {1,2,…,Ν}. Το αντικείμενο k έχει μέγεθος size(k) και αξία value(k). Ο σκοπός μας είναι να γεμίσουμε με τα αντικείμενα αυτά ένα σακίδιο μεγέθους M έτσι ώστε η συνολική αξία των αντικειμένων να είναι η μέγιστη δυνατή.

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Το πρόβλημα του σακιδίου (knapsack problem) Μ=20 size(1) = 12 value(1)= 20 size(2) = 8 value(2)= 14 size(3) = 6 value(3)= 11 size = 18 value = Έχουμε Ν τύπους αντικειμένων {1,2,…,Ν}. Το αντικείμενο k έχει μέγεθος size(k) και αξία value(k). Ο σκοπός μας είναι να γεμίσουμε με τα αντικείμενα αυτά ένα σακίδιο μεγέθους M έτσι ώστε η συνολική αξία των αντικειμένων να είναι η μέγιστη δυνατή.

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Το πρόβλημα του σακιδίου (knapsack problem) Μ=20 size(1) = 12 value(1)= 20 size(2) = 8 value(2)= 14 size(3) = 6 value(3)= 11 size = 20 value = βέλτιστη λύση Έχουμε Ν τύπους αντικειμένων {1,2,…,Ν}. Το αντικείμενο k έχει μέγεθος size(k) και αξία value(k). Ο σκοπός μας είναι να γεμίσουμε με τα αντικείμενα αυτά ένα σακίδιο μεγέθους M έτσι ώστε η συνολική αξία των αντικειμένων να είναι η μέγιστη δυνατή.

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Το πρόβλημα του σακιδίου (knapsack problem) static class Item { int size; int val; } Item item[N];... int knap(int M) { int i, space, t, max = 0; for (i = 0; i < N; i++) if ( (space = M – items[i].size) >= 0 ) if ( (t = knap(space) + items[i].val > max ) max = t; return max; } Έχουμε Ν τύπους αντικειμένων {1,2,…,Ν}. Το αντικείμενο k έχει μέγεθος size(k) και αξία value(k). Ο σκοπός μας είναι να γεμίσουμε με τα αντικείμενα αυτά ένα σακίδιο μεγέθους M έτσι ώστε η συνολική αξία των αντικειμένων να είναι η μέγιστη δυνατή.

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Το πρόβλημα του σακιδίου (knapsack problem) Έχουμε Ν τύπους αντικειμένων {1,2,…,Ν}. Το αντικείμενο k έχει μέγεθος size(k) και αξία value(k). Ο σκοπός μας είναι να γεμίσουμε με τα αντικείμενα αυτά ένα σακίδιο μεγέθους M έτσι ώστε η συνολική αξία των αντικειμένων να είναι η μέγιστη δυνατή. static class Item { int size; int val; } Item item[N];... int knap(int M) { int i, space, t, max = 0; for (i = 0; i < N; i++) if ( (space = M – items[i].size) >= 0 ) if ( (t = knap(space) + items[i].val > max ) max = t; return max; } δοκιμάζει όλους τους εφικτούς συνδυασμούς εκθετικός χρόνος εκτέλεσης!

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Το πρόβλημα του σακιδίου (knapsack problem) int knap(int M) { int i, space, t, maxi, max = 0; if ( maxKnown[M] != unknown ) return maxKnown[M]; for (i = 0; i < N; i++) if ( (space = M – items[i].size) >= 0 ) if ( (t = knap(space) + items[i].val > max ) {max = t; maxi = i; } maxKnown[M] = max; itemKnown[M] = items[maxi]; return max; } Έχουμε Ν τύπους αντικειμένων {1,2,…,Ν}. Το αντικείμενο k έχει μέγεθος size(k) και αξία value(k). Ο σκοπός μας είναι να γεμίσουμε με τα αντικείμενα αυτά ένα σακίδιο μεγέθους M έτσι ώστε η συνολική αξία των αντικειμένων να είναι η μέγιστη δυνατή.

TexPoint fonts used in EMF. Read the TexPoint manual before you delete this box.: AA A Δυναμικός Προγραμματισμός Το πρόβλημα του σακιδίου (knapsack problem) int knap(int M) { int i, space, t, maxi, max = 0; if ( maxKnown[M] != unknown ) return maxKnown[M]; for (i = 0; i < N; i++) if ( (space = M – items[i].size) >= 0 ) if ( (t = knap(space) + items[i].val > max ) {max = t; maxi = i; } maxKnown[M] = max; itemKnown[M] = items[maxi]; return max; } Χρόνος εκτέλεσης : Εφαρμόσαμε αναλυτικό δυναμικό προγραμματισμό! Έχουμε Ν τύπους αντικειμένων {1,2,…,Ν}. Το αντικείμενο k έχει μέγεθος size(k) και αξία value(k). Ο σκοπός μας είναι να γεμίσουμε με τα αντικείμενα αυτά ένα σακίδιο μεγέθους M έτσι ώστε η συνολική αξία των αντικειμένων να είναι η μέγιστη δυνατή.