1 / 33

Lecture 5 Dynamic Programming

Lecture 5 Dynamic Programming. Dynamic Programming. Self-reducibility. Divide and Conquer. Divide the problem into subproblems. Conquer the subproblems by solving them recursively. Combine the solutions to subproblems into the solution for original problem. Dynamic Programming.

inez
Télécharger la présentation

Lecture 5 Dynamic Programming

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Lecture 5 Dynamic Programming

  2. Dynamic Programming Self-reducibility

  3. Divide and Conquer • Divide the problem into subproblems. • Conquer the subproblems by solving them recursively. • Combine the solutions to subproblems into the solution for original problem.

  4. Dynamic Programming • Divide the problem into subproblems. • Conquer the subproblems by solving them recursively. • Combine the solutions to subproblems into the solution for original problem.

  5. Remark on Divide and Conquer Key Point: Divide-and-Conquer is a DP-type technique.

  6. Greedy Algorithms with Self-Reducibility Dynamic Programming Divide and Conquer Local Ratio

  7. Matrix-chain Multiplication

  8. Fully Parenthesize

  9. Scalar Multiplications

  10. e.g., # of scalar multiplications

  11. Step 1. Find recursive structure of optimal solution

  12. Step 2. Build recursive formula about optimal value

  13. Step 3. Computing optimal value

  14. Step 3. Computing optimal value

  15. Step 4. Constructing an optimalsolution

  16. 151 15,125 11,875 10,500 9,375 7,125 5,375 7,875 4,375 2,500 3,500 15,700 2,625 750 1,000 5,000 0 0 0 0 0 0

  17. 151 15,125 (3) 11,875 10,500 (3) (3) 9,375 7,125 5,375 (3) (3) (3) 7,875 4,375 2,500 3,500 (1) (3) (3) (5) 15,700 2,625 750 1,000 5,000 (1) (2) (3) (4) (5) 0 0 0 0 0 0 Optimal solution

  18. Running Time

  19. Running Time How many recursive calls? How many m[I,j] will be computed?

  20. # of Subproblems

  21. Running Time

  22. Remark on Running Time (1) Time for computing recursive formula. (2)The number of subproblems. (3) Multiplication of (1) and (2)

  23. Longest Common Subsequence

  24. Problem

  25. Recursive Formula

  26. More Examples

  27. A Rectangle with holes NP-Hard!!!

  28. Guillotine cut

  29. Guillotine Partition A sequence of guillotine cuts Canonical one: every cut passes a hole.

  30. Minimum length Guillotine Partition • Given a rectangle with holes, partition it into smaller rectangles without hole to minimize the total length of guillotine cuts.

  31. Minimum Guillotine Partition Dynamic programming In time O(n ): 5 Each cut has at most 2n choices. 4 There are O(n ) subproblems. Minimum guillotine partition can be a polynomial-time approximation.

  32. What we learnt in this lecture? • How to design dynamic programming. • Two ways to implement. • How to analyze running time.

  33. Puzzle

More Related