我是靠谱客的博主 温婉季节,这篇文章主要介绍树形DP—依赖背包模板,现在分享给大家,希望可以做个参考。

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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—依赖背包模板内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(93)

评论列表共有 0 条评论

立即
投稿
返回
顶部