A. Adore

似乎是显然的状压。

$dp_{i,S}$表示第$i$层,其中每个点到达终点路径条数的奇偶性为$S$的方案数。

直接用位运算转移,复杂度是$O(m*k*2^k)$,然后卡卡常(把$k$循环展开)就过了。

似乎考虑单次的变化量,可以继续消掉一个$k$,然后就好了。

 

 

 

B. Confess

手玩发现合法的状态一定很多,

所以直接随机集合对搞就好了。

实际上集合对的交的期望是很大的。

设$cnt_i$表示元素$i$出现的次数。

$$E=\sum \limits_{i=1}^{2*n}\frac{\binom{cnt_i}{2}}{\binom{n+1}{2}}$$

$$=\frac{\sum \limits_{i=1}^{2*n}cnt_i*(cnt_i-1)}{n*(n+1)}$$

上式在所有的$cnt_i$相等时取得最小值,即$cnt_i=\frac{n+1}{2}$。

所以上式$=\frac{n-1}{2}$。

然而答案只要求出集合交为$\frac{n}{2}$,实际上在随机情况下每次随机到的概率为$\frac{1}{2}$。

 

 

 

C. Repulsed

被原来做过的一道类似的贪心题思想钳制住了。

那道题的贪心思想是,每次取出深度最大的,

之后不断翻祖先,将可以覆盖到的点覆盖掉。

然而复杂度是$O(n^2)$的。

似乎这个贪心过程可以用$dfs$的方式解决。

$g_{x,i}$表示节点$x$,深度为$i$剩余的未匹配节点。

$f_{x,i}$表示节点$x$,深度为$i$处的灭火器还能匹配的节点个数。

在子树中匹配掉一定更优,所以贪心在$lca$处匹配就好了。