(题目链接)
题意
给出一棵树,要求在不存在两个节点相邻的条件下,选出尽可能多的节点,并且判断是否有多种选法。
Solution
很水的树形dp,2个月前的自己Wa的不要不要的,现在的自己1A。。
${f[i][0]}$表示${i}$不去的最大人数,${f[i][1]}$表示${i}$去的最大人数。关键是如何去判断方案的唯一性。
对于节点${x}$,我们分情况讨论。
1.${x}$去更优。${f[x][1]}$只能由${f[son[x]][0]}$转移过来,那么方案肯定是唯一的,所以我们直接去搜索${son[x]}$的儿子节点。
2.${x}$不去更优。${f[x][0]}$能由${f[son[x]][0]}$或者是${f[xon[x]][1]}$转移过来,而如果${f[x][0]}$的值可以由多种方案得到,那么必然是${x}$的某个儿子节点去和不去的人数相等。
3.${x}$去与不去的人数相等。那么直接返回1。。
至此,问题已经解决。
代码
// poj3342#include #include #include #include #include #include #include #include