首页 > 代码库 > dp表模型-如何写出for循环动态规划

dp表模型-如何写出for循环动态规划

题目很肤浅。。

但是这件事我们要做。。

那么有一种方法叫做刷表法。。

当你发现这个问题具有最优子结构,重叠子问题时

那么这是一个dp问题是使用本方法的前提

画出该dp状态所对应的矩阵

画出转移关系线。。。找出前置依赖的所有状态

如果我们能找到该表的一个遍历顺序可以使得

每次计算都依赖之前已经计算好的结果计算出来

那么我们就能正确地写出这个dp的递推写法

举个例子。。矩阵链乘法是按dp表对角线转移

而最长公共子序列就正常m*n地for转移

=============

这是解决dp问题的一个典型的dp表模型。。

但是对于背包问题等跳跃性引用表项。。我们需要小心

目前积累的dp模型太少还需要进一步去积累

合并石子与矩阵链乘法类似。。

最长公共子序列。。

==========

我们还有一个工作要做

那就是确定最先应该被确定好的依赖项的值

相当于边界值。。那么我们就要十分清楚状态的语义和数据定义

dp表模型-如何写出for循环动态规划