DEV Community

Cover image for Dynamic Programming
Federico Diaz Aguirre
Federico Diaz Aguirre

Posted on

3 1 1 1

Dynamic Programming

Context

When facing recursive problems we quickly identify the memorization enhancement to avoid wasting cycles for past computations. But what about the underlying implementations top-down vs bottom-up?

In the video below I am comparing these two. And the drawbacks of using BFS in this particular case:

  1. Higher memory usage due to maintaining a queue and a visited set.
  2. Worse than DP for large amount values (since BFS explores level by level, it can be slow for high values).

Summary

Visual representation

Image description

Comparisson

Approach Time Complexity Space Complexity Notes
Recursive DP (Top-Down w/ Memoization) O(amount × len(coins)) O(amount) Efficient, but recursion uses stack memory
Iterative DP (Bottom-Up) O(amount × len(coins)) O(amount) Best for dense subproblem coverage
BFS (Graph Traversal) O(amount × len(coins)) (Worst case) O(amount) Can be more efficient for small values

Image of Quadratic

AI spreadsheet assistant for easy data analysis

Chat with your data and get insights in seconds with the all-in-one spreadsheet that connects to your data, supports code natively, and has built-in AI.

Try Quadratic free

Top comments (0)

Sentry image

See why 4M developers consider Sentry, “not bad.”

Fixing code doesn’t have to be the worst part of your day. Learn how Sentry can help.

Learn more

👋 Kindness is contagious

Please leave a ❤️ or a friendly comment on this post if you found it helpful!

Okay