比较难想的的一道树形dp. 看到这道题正常的思路应该是$f[i][j][k]$表示i这棵子树里买了j个i物品花费为k的最大收益. 但如果直接这么定义的话转移复杂度会很高,需要枚举j,枚举孩子,枚举k,枚举孩子的花费,还要枚举每个孩子各买了多少件. 想办法把最后一个循环去掉. 重新定义状态$f[i][j][k]$表示表示i这棵子树里至少买了j个i物品花费为k的最大收益. 每次枚举完物品数量后加上这么一句 if(i!=l[x])f[x][i][j]=max(f[x][i][j],f[x][i+1][…