Presentation is loading. Please wait.

Presentation is loading. Please wait.

Dynamic Programming General Idea

Similar presentations


Presentation on theme: "Dynamic Programming General Idea"— Presentation transcript:

1 Dynamic Programming General Idea
Problem can be divided into stages with a policy decision required at each stage. (Solution is a sequence of decisions) Each stage has a number of states associated with it. The effect of the policy decision at each stage is to transform the current state into a state in the next stage. Given a current state, the optimal policy for the remaining stages is independent from the policy adopted in the previous stages. (The decision at the current stage is based on the results of the previous stage, but decisions are independent) Young CS 331 D&A of Algo Dynamic Programming

2 Dynamic Programming General Idea
“Principle of optimality” : A decision sequence can be optimal only if the decision sequence that takes us from the outcome of the initial decision is itself optimal.  eliminates “not optimal” subsequences The solution procedure begins by finding the optimal policy for the last stage.(backward approach) Then, a recursive relationship that represents the optimal policy for each stage can be generated. Young CS 331 D&A of Algo Dynamic Programming

3 Greedy & Dynamic Programming
- Consider only 1 seq. of decisions Dynamic Programming: Consider many seq. of decisions Try all possibilities Young CS 331 D&A of Algo Dynamic Programming

4 Divide and conquer: divide the problem into subproblems
Divide and conquer: divide the problem into subproblems. Solve each subproblem independently and then combine the solutions. Ex: Assume n = 5 Young CS 331 D&A of Algo Dynamic Programming

5 0 1 1 2 3 5 8 . . . But Dynamic Programming: works on phases:
Based on the results in previous phase, make our decision for the current phase Can be solved in a for-loop F(0) = 0 F(1) = 1 For i  2 to n F(i) = F(i-1) + F(i-2); Young CS 331 D&A of Algo Dynamic Programming

6 Multistage Single-source Single-destination Shortest Path
The problem: Given: m columns (or stages) of n nodes assume edge only exist between stages Goal: to find the shortest path from the source (0, 1) to the destination (m-1,1) Stage number Node number of that stage Young CS 331 D&A of Algo Dynamic Programming

7 The straight forward way: Time complexity is as there are that many
different paths. The Dynamic Programming way: Let m(i, j) = length of the shortest path from the source (0,1) to (i, j) c(i, k, j)=distance from (i, k) to (i+1, j) want to find m(m-1, 1) define the function equation: Shortest path of source (0,1)  destination (m-1,1) Young CS 331 D&A of Algo Dynamic Programming

8 Ex: Source Destination m: Stage # 1 3 4 2 5 3 4 Young
0,1 1,1 1,2 1,3 2,1 2,2 2,3 1 3 4 2 5 3,1 3,2 3,3 4,1 Source Destination m: Stage # Young CS 331 D&A of Algo Dynamic Programming

9 Remember the previous node of this shortest path Can be used
for constructing the shortest path at the end Young CS 331 D&A of Algo Dynamic Programming

10 Time complexity is O(mn) to compute m(i, j), each m(i, j)
The shortest path is: Time complexity is O(mn) to compute m(i, j), each m(i, j) also takes O(n) comparisons. Total complexity is O(mn2). Let N = m  n nodes # of nodes in the graph max # of stages max # of nodes in each stage We have mn2 = mn  n = N  n Note: if use the Dijkstra’s algorithm, the complexity is O(N2) Young CS 331 D&A of Algo Dynamic Programming

11 Revisit Dynamic Programming
The problem can be divided into stages. Need to make decisions at each stage. The decision for the current stage(based on the results of the previous stage) is independent from that of the previous stages, e.g. look at node 3,1 of the multistage shortest path problem, it chooses among 3 decisions from nodes 2,1 or 2,2 or 2,3 but it is independent from how node 2,1 (2,2 or 2,3) makes its decision. Note that we find shortest paths from the source to all three nodes 2,1 and 2,2 and 2,3, but some of them may not be used on the shortest path at all. But every decision must be optimal, so that the overall result is optimal. This is called “Principle of Optimality”. Young CS 331 D&A of Algo Dynamic Programming

12 2. 0/1 Knapsack The problem: Given n objects, p1 , p2 , …, pn, profit,
knapsack of capacity M, w1 , w2 , …, wn,weight Goal: find x1 , x2 , …, xn s.t is maximized subject to where xi = 0 or 1 Young CS 331 D&A of Algo Dynamic Programming

13 The straight forward way:
The complexity is O(2n) Example: Young CS 331 D&A of Algo Dynamic Programming

14 This problem can’t use Greedy ( Pi / Wi  order)
Does Greedy work? This problem can’t use Greedy ( Pi / Wi  order) Counter-example: Homework Exercise The Dynamic Programming way: Define notation: = max profit generated from subject to the capacity X Young CS 331 D&A of Algo Dynamic Programming

15 Use backward approach:
Example: Question: to find Use backward approach: Young CS 331 D&A of Algo Dynamic Programming

16 The result: . . . . . . . . . Therefore, the complexity of 0/1 Knapsack is O(2n) Young CS 331 D&A of Algo Dynamic Programming

17 1 … j-wi j M i-1 fi-1(j-wi) fi-1(j) i fi(j) n M+1 n+1 +pi
1 j-wi j M i-1 fi-1(j-wi) fi-1(j) i fi(j) n n+1 +pi (M+1)(n+1) entries and constant time each  O(Mn) Young CS 331 D&A of Algo Dynamic Programming

18 1 2 3 4 5 6 7 8 12 9 Example: M = 6 Max profit is 12
Object 1 Object 2 Object 3 Object 4 pi 3 4 8 5 wi 2 1 1 2 3 4 5 6 7 8 12 9 +8 +5 Max profit is 12 By tracing which entries lead to this max-profit solution, we can obtain the optimal solution - Object 1,2 and 4. Young CS 331 D&A of Algo Dynamic Programming

19 Chained Matrix Multiplication
The problem: Given M1  M2   Mr [d0 d1] [d1d2] [dr-1 dr] (r matrices) Goal: find the minimum cost of computing M1  M2   Mr Young CS 331 D&A of Algo Dynamic Programming

20 (the total # of elementary multiplications )
The idea: Define C(i, j) = minimum cost of computing MiMi+1. . .Mj Goal: To find C(1,r) (minimum cost of computing M1M2. . .Mr ) C(i, i) = i (the total # of elementary multiplications ) Sequence matrices from i to j: k: divide-point, Young CS 331 D&A of Algo Dynamic Programming

21 B A We divide it into two parts with divide-point k,
Define the functional equation: Cost of multiplying A and B Young CS 331 D&A of Algo Dynamic Programming

22 Example: size 1 size 2 Young CS 331 D&A of Algo Dynamic Programming

23 It has the smallest cost when k = 2.
size 3 Smallest size 4 It has the smallest cost when k = 2. Remember this k-value and it can be used for obtaining the optimal solution. Young CS 331 D&A of Algo Dynamic Programming

24 procedure MinMult (r, D, P) // r, D - inputs, P -output begin
Algorithm: procedure MinMult (r, D, P) // r, D - inputs, P -output begin for i  1 to r do C(i, i) = 0 for d  1 to (r –1) do for i  1 to (r –d) do end; Young CS 331 D&A of Algo Dynamic Programming

25 # of products with this size # of operations required
Analysis: Size of the product i & j # of products with this size # of operations required size 1 j = i + 0 size 2 j = i + 1 r – 1 1 size 3 j = i +2 r – 2 2 size r j = i + (r – 1) r – (r – 1) = 1 r - 1 . . . . . . . . . . . . # of C(i, j)’s is O(r2) For computing each C(i, j): O(r) time Total complexity is O(r3) Young CS 331 D&A of Algo Dynamic Programming


Download ppt "Dynamic Programming General Idea"

Similar presentations


Ads by Google