Skip to main content

树形 DP

参考资料

实现

106 Bcpp
void dfs(int u)
{
for(auto v:G[u])
{
dfs(v);
f[u][0]+=max(f[v][0],f[v][1]);
f[u][1]+=f[v][0];
}
}

换根 DP

详见 树的重心

例题

某大学有 nn 个职员,编号为 1n1\dots n

他们之间有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司。

现在有个周年庆宴会,宴会每邀请来一个职员都会增加一定的快乐指数 rir_i,但是呢,如果某个职员的直接上司来参加舞会了,那么这个职员就无论如何也不肯来参加舞会了。

请计算邀请哪些职员可以使快乐指数最大,求最大的快乐指数。

给定一个 nn 个点的树,请求出一个结点,使得以这个结点为根时,所有结点的深度之和最大。

一个结点的深度之定义为该节点到根的简单路径上边的数量。