• pinchcramp@lemmy.dbzer0.com
    link
    fedilink
    arrow-up
    6
    ·
    10 months ago

    Am I understanding this correctly that dynamic programming == breaking a problem into smaller (reoccurring) sub-problems and using caching to improve performance?

    • bitcrafter@programming.dev
      link
      fedilink
      arrow-up
      3
      ·
      10 months ago

      That is conceptually how dynamic programming works, but in practice the way you build the cache is from the bottom up rather than from the top down. It’s a bit like how you can implement computation of the Fibonacci sequence in a top-down manner using a recursive function with caching, but it is a lot more efficient to instead build it in a bottom-up manner.