题目大概是给一棵树,问最少删几条边可以出现一个包含点数为p的连通块. 任何一个连通块都是某棵根属于连通块的子树的上面一部分,所以容易想到用树形DP解决: dp[u][k]表示以u为根的子树中,包含根的大小k的连通块最少的删边数 要求答案就是min(dp[u][p],min(dp[v][p]+1)),u是整棵树的根,v是其他结点 转移从若干个子树各自选择要提供几个k转移,不过指数级时间复杂度,当然又是树上背包了.. 转移好烦,写得我好累好累..还好1A了.. #include<cstdio> #…