树形DP—依赖背包模板

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是核心思想,以后再来填坑。

相关文章

迭代器模式(Iterator)迭代器模式(Iterator)[Cursor]意图...
高性能IO模型浅析服务器端编程经常需要构造高性能的IO模型,...
策略模式(Strategy)策略模式(Strategy)[Policy]意图:定...
访问者模式(Visitor)访问者模式(Visitor)意图:表示一个...
命令模式(Command)命令模式(Command)[Action/Transactio...
生成器模式(Builder)生成器模式(Builder)意图:将一个对...