Præsentation er lastning. Vent venligst

Præsentation er lastning. Vent venligst

Algoritmer og Datastrukturer 2 Dynamisk Programmering [CLRS, kapitel 15] Gerth Stølting Brodal Aarhus Universitet.

Lignende præsentationer


Præsentationer af emnet: "Algoritmer og Datastrukturer 2 Dynamisk Programmering [CLRS, kapitel 15] Gerth Stølting Brodal Aarhus Universitet."— Præsentationens transcript:

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

16

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


Download ppt "Algoritmer og Datastrukturer 2 Dynamisk Programmering [CLRS, kapitel 15] Gerth Stølting Brodal Aarhus Universitet."

Lignende præsentationer


Annoncer fra Google