动态规划
动态规划(Dynamic Programming,DP)是一种优化问题求解方法,通常用于解决具有 重叠子问题 和 最优子结构 性质的问题。它的基本思想是将原问题分解成更小的子问题,通过求解和保存这些子问题的解,避免重复计算,从而提高算法的效率。
基本概念:
-
最优子结构:
- 最优子结构是指问题的最优解可以通过
子问题的最优解递归
构建而成。在动态规划中,原问题被分解为更小的子问题,每个子问题都有自己的最优解。通过合并这些最优解,我们可以得到整体问题的最优解。
- 最优子结构是指问题的最优解可以通过
-
重叠子问题:
- 动态规划问题会涉及到重叠子问题,即在解问题的过程中会多次遇到
相同的子问题
。为了避免重复计算,动态规划使用记忆化或者其他方法来保存子问题的解。
- 动态规划问题会涉及到重叠子问题,即在解问题的过程中会多次遇到
-
状态转移方程:
- 状态转移方程是问题建模的关键,它描述了问题的
当前状态
和如何从之前的状态
- 状态转移方程是问题建模的关键,它描述了问题的