O documento apresenta os conceitos de programação dinâmica e subproblemas sobrepostos. Apresenta exemplos como a sequência de Fibonacci e distância de edição que podem ser resolvidos usando programação dinâmica, devido à presença de subproblemas sobrepostos. Também fornece implementações recursivas, iterativas e com cache destes problemas para ilustrar a abordagem de programação dinâmica.
9. Overlapping Subproblems
Problemas que podem ser divididos em sub-problemas e reusados
consecutivamente até que a solução desejada seja obtida.
Para que um problema possa ser resolvido utilizando programação
dinâmica o primeiro passo é encontrar a sua relação de recorrência.
24. Alinhamento de Sequências de DNA
Distâ palavras n e m geralmente são < 10
Sequências de DNA podem ter Gigabytes de
informação
25. Bônus: Dynamic Time Warping (DTW)
Usado para alinhamento de
séries temporais.
Ver: https://en.wikipedia.org/wiki/Dynamic_time_warping
26. Mais a respeito do tema
https://ocw.mit.edu/courses/electrical-engineering-and-computer-science/6-00-introduction-to-computer-sc
ience-and-programming-fall-2008/video-lectures/lecture-13/
http://www.geeksforgeeks.org/dynamic-programming-set-5-edit-distance/
https://people.eecs.berkeley.edu/~vazirani/algorithms/chap6.pdf
27. Como eu chego lá? Preparação
"Se mantenha curioso" – Aron Swartz
30. Desafios
"The brick walls are not there to keep us out; the brick walls are there to give us a
chance to show how badly we want something." – Randy Pausch