Download præsentationen
Præsentation er lastning. Vent venligst
Offentliggjort afIngeborg Axelsen Redigeret for ca. et år siden
1
Algoritmer og Datastrukturer 2 Dynamisk Programmering [CLRS, kapitel 15] Gerth Stølting Brodal Aarhus Universitet
2
Dynamisk Programmering Generel algoritmisk teknik – virker for mange (men langt fra alle) problemer Krav: ”Optimal delstruktur” – en løsning til problemet kan konstrueres ud fra optimale løsninger til ”delproblemer” Rekursive løsning: –Typisk eksponentiel tid Dynamisk Programmering: –Beregn delløsninger systematisk: –Typisk polynomiel tid
3
”Colonel Motors Corporation” Mål Find en hurtigste vej fra ”Chassis enters” til ”completed auto” – knuderne angiver hvor lang tid de forskellige ting tager Naive algoritme Prøv alle 2 n forskellige veje – tid Ω(2 n )
4
”Colonel Motors Corporation” Korteste tid til og med stationerne Forrige station for hurtigste løsning
5
”Colonel Motors Corporation” Længden af den hurtigste vej findes i tid O(n)
6
”Colonel Motors Corporation” Gå ”baglæns” igennem de beregnede værdier, og find løsningen
7
Matrix-kæde Multiplikation Multiplikation af to matricer A og B af størrelse p 1 x p 2 og p 2 x p 3 tager tid O(p 1 ·p 2 ·p 3 )
8
(A·B)·C elller A·(B·C) ? Matrix-kæde Multiplikation Matrix multiplikation er associativ (kan sætte paranteser som man vel) men ikke kommutative (kan ikke bytte rundt ¨på rækkefølgen af matricerne)
9
Problem: Find den bedste rækkefølge (paranteser) for at gange n matricer sammen A 1 · A 2 ·.... · A n hvor A i er en p i-1 x p i matrice NB: Der er Ω(4 n /n 3/2 ) mulige måder for paranteserne Matrix-kæde Multiplikation
10
m[i,j] = minimale antal (primitive) multiplikationer for at beregne A i ·…· A j Matrix-kæde Multiplikation Tid Ω(4 n /n 3/2 )
11
Matrix-kæde Multiplikation Tid O(n 3 )
12
Matrix-kæde Multiplikation
13
Tid O(n)
14
”Memoized” Matrix-kæde Multiplikation Tid O(n 3 )
15
B D C A B A A B C B D A B Længste Fælles Delsekvens
17
Tid O(nm)
18
Længste Fælles Delsekvens Tid O(n)
19
Optimale Binære Søgetræer Forventet søgetid 2.80 Forventet søgetid 2.75
20
Optimale Binære Søgetræer
21
Tid O(n 3 )
22
Dynamisk Programmering Generel algoritmisk teknik Krav: ”Optimal delstruktur” – en løsning til problemet kan konstrueres ud fra optimale løsninger til ”delproblemer” Eksempler –”Colonel Motors Corporation” –Matrix-kæde multiplikation –Længste fælles delsekvens –Optimale søgetræer
Lignende præsentationer
© 2024 SlidePlayer.dk Inc.
All rights reserved.