题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1561 题意:n座城堡,每个里面都有宝物,要求在你可以攻占m个城堡得到的最多的宝物,但是如果要攻破一个城堡,必须要攻破它依赖的那个城堡,例如,如果a依赖b,那么如果想要攻破a就必须先攻破b. 分析:首先根据依赖关系构建出一棵以0为根节点的树,那么按从上往下的顺序攻取,除了0节点外,在攻取它的子节点前必须先占领了根节点.dp[u][j]表示以u为根节点占领了j个节点取得的最大值,因此:dp[u][j]=…