Dynamic Programming¶
Introduction¶
DP V.S. D.C.
Similarities:
- partition the problem into subproblems
- combining the solutions from subproblems
Differences:
- overlapping subproblems vs. no overlapping subproblems
- Synamic programming is typically applied to optimization problems
- We want the optimal value, not every optimal solution
Steps¶
- Characterize the structure of an optimal solution
- use a function \(f\) to characterize that "state"
- Recursively define the value of an optimal solution
- Find subproblems
- Compute the value of an optimal solution in a bottom-up fashion
- Give the "state" transformation formula
- Construct an optimal solution from computed information
- Sometimes it can be ignored
- if we want the solution, we should maintain more information in step 3
Principles - how to prove the optimial substructure proeperty¶
Build substructure, you may need to do some choice, which generates a series of subproblems.
Cut-paste method:
- Suppose the solution of subproblem is not optimal, then we can replace it with " real optimal solution", then we can get a better solution. Contradicted.
The subproblems should be independent, that is to say, the solution to one subproblem does not affect the solution to another subproblem of the same problem.
Estimate running time:
- The number of subproblems overall
- The number of choices(The time we spent) for each subproblem
Implementation¶
- Recursive, top-down, but with a memoization
- Bottom-up, with a array
Problems¶
Rot Cutting¶
Given a rod of length \(n\). Assume that price of an \(i\)-inches rod is \(p_i\).
We want to cut the rod into several pieces to get the most price.
Matrix Chain¶
We want to calculate \(A_1A_2 \cdots A_n\). Since matrix multiplication has associativity, we can parenthesized it.
Example
\((A_1(A_2(A_3A_4)))\),\((A_1((A_2A_3)A_4))\),\(((A_1A_2)(A_3A_4))\), \(((A_1(A_2A_3))A_4)\),\((((A_1A_2)A_3)A_4)\).
Suppose that \(A_i\) has size \(p_{i-1} \times p_i\).
- Step1: characterize the structure of optimal solution
\(m[i,j]\) is the minimum price to multiply \(A_i \cdots A_j\), the "optimal substructure" property is very trivial.
- Step2: Get the recursive solution
Longest common subsequence¶
Optimal Binary Search Trees¶
Optimal Substructure:
Solution: