Explain the concept of dynamic programming.
Dynamic programming is a problem-solving technique where a complex problem is solved by breaking it into simpler overlapping subproblems, and solutions to subproblems are stored to avoid redundant computations.