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.jb51.cc/javaschema/284097.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。