A. 选择

可以发现问题是$a$ $b$是否在一个边双里。

因为没有强制在线,所以将难处理的删边转化为加边。

对于一棵树上的加边操作,只要将两个点之间的路径上的点,添加到同一个边双集合里即可。

因为边双的特殊性质,加上并查集的操作,这样只考虑树边的做法是正确的。

具体的实现方法实际上通过并查集+暴力跳父亲就可以实现。

但是因为考试时弱智了,用的树剖+线段树维护并查集。


B. 划分序列

对于权值为正数,合法条件为最小的组数<=k。

对于权值为负数,合法条件为最大的组数>=k。

对于权值任意,可以尝试理解一个结论:合法条件为最小组数<=k<=最大组数。

将前缀和离散化,然后直接通过树状数组即可维护最小的组数和最大的组数。

所以直接二分答案就可以了。

 

C. 生成树求和

实际上也与原题差不多了。

生成树一题的做法是,将三种颜色的边,分别视为$1$,$x$,$y$。

然后代入$n^2$组点值,二维插值可得系数,而所得$x^ay^b$项系数即选择了$a$条颜色二边,$b$条颜色三边,$n-1-a-b$条颜色一边的方案数。

对于本题,显然可以按位处理。

一个显然的做法是同样将三种边权看作三种颜色,同样用二维插值解决。

但是一个更加优秀的做法是,因为本题的特殊性质(最终不关注具体的$a$,$b$),而只关注$a+2b$ $mod$ $3$的结果。

也就是说我们要得到每个生成树方案的边权的加和。

因为矩阵树求的是乘积,所以只要将这个边权放在指数上就行了。

这样求得的多项式也变为了不到$2n$次,用一维插值就可以,总复杂度少一个$n$。

 

D. 圆圈游戏

因为一些特殊的原因,这次的分数又超过了300分。

因为一些特殊的原因,这是一道原题,题解见省选模拟4