pku acm1579简单动态规划

来源:互联网 发布:js修改offsetleft 编辑:程序博客网 时间:2024/05/29 07:04

题目所给的函数就是递归函数,要是按照函数本身写递归式,由于子问题的扩展速度太快扩展范围太大,结果肯定是TLE。
因此,为了减少重复计算,引入一个三维数组。每次从w(a,b,c)开始递推时,在子问题中只要s[x][y][z]有返回值就记录一次;如果在递归过程中,遇到s[x][y][z]已被赋值,则在此子问题中不再进行递归,直接返回值s[x][y][z].
小结:这道题是很地道的DP,由于子问题过多,可以将问题的结果保存起来,避免重复递归。问题虽然简单,但包含很经典的dp思想。