加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

树形DP—依赖背包模板

发布时间:2020-12-14 02:16:46 所属栏目:百科 来源:网络整理
导读:void DP(int x){ for(int i=0;i=t;i++){ dp[x][i]=p[x].val; } for(int i=0;ison[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[so
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是核心思想,以后再来填坑。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读