题意:一颗二叉苹果树树上结苹果,要求剪掉几棵枝,然后求保留Q根树枝能保留的最多到苹果数。
方法:典型的树形DP,第一次做,看不出来。。。。晓东有一种邻接表的常数优化方法以及免建树方法,但我还是觉得建树后思路更加清晰。
还是老问题,寻找状态。这次的状态是ans[i][j]表示以i为树根,j条边能采摘的最大苹果数。与此同时,因为所有的苹果都结在边上,但是我们可以将之平移到叶子方向的节点上,这样根节点root就要假设有一条虚拟边接在其上,且其苹果数为0.这样不难获得状态转移方程
ans[i][j] = max(ans[i.leftchild][k] + ans[i.rightchild][j-k-1]) + i.val (i.leftchild表示其左孩子的编号,i.val表示i与其父节点相连的那条边上的苹果数),这样对于第i个节点ans[i][j]就会必取i与其父节点相连的那条边最终形成j条边。当j=0时,ans[i][j] = 0。
由于多了一条虚拟边,注意DP时边数要加一。
代码: