概述
void DP(int x){
for(int i=0;i<=t;i++){
dp[x][i]=p[x].val;
}
for(int i=0;i<son[x].size();i++){
if(in[son[x][i]]==1)
continue;
DP(son[x][i]);
int lim=val[x][i];
for(int j=t;j>=lim;j--){
for(int k=0;k<=j-lim;k++)
dp[x][j]=max(dp[x][j-lim-k]+dp[son[x][i]][k],dp[x][j]);
}
}
return ;
}
最近做了几道依赖背包,中间还有很多不懂的地方,
大体思路是普通树形dp的框架,加上一个枚举孩子,其中枚举k是核心思想,以后再来填坑。
转载于:https://www.cnblogs.com/zhangxianlong/p/10672598.html
最后
以上就是温婉季节为你收集整理的树形DP—依赖背包模板的全部内容,希望文章能够帮你解决树形DP—依赖背包模板所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复