A. 杨柳
考虑实际上有这样一个结论,棋子之间是互不干扰的。
可以使得最优方案上不存在两个棋子中途碰上的情况。
然后问题就是一个二分图最小匹配,一个简单的想法就是 bfs 然后跑一个费用流,点数不多,边数很多。
另外一个做法是直接在原图上建图跑个费用流,点数很多,边数不多。
经过实验,只有后者比较可行。
B. 景中人
主要没想明白的是,因为只关注最终用了多少个矩形。
所以当确定一个矩形长度边界的时候,最优的高度是可以计算出来的。
然后有这样一个结论,矩形左右边界之间的关系只存在包含和不交。
所以写一个区间 dp。
另外的,为了处理不交关系的矩形,在 dp 过程中记录一下已经处理完了所有 $\leq v$ 的点。
这样每次只要考虑包含所有矩形的那个大矩形,最优的高度肯定是 $\frac{S}{x_r-x_l}$。
C. 钦点
考虑暴力咋做,发现边数太多了。
那就建一些虚点,使每个实点都向虚点连边就可以解决。
然后发现这样一个事情。
虚点和实点之间连成一个菊花,只可以割实点。
和原图可以割所有点是等价的。
前者的边数不是很多,所以就可以做了。
因为要求割一个点之后的最大连通块,这肯定是一个点双问题。
所以缩完点双之后,在最大的连通块中找一下树上的最优的分裂点就结束了。
但是这样没有必要,因为只关注每个割点的每个子树中的实点个数,其实只要在 $tarjan$ 求割点的同时求一下就好了。
然后问题是求所有的约数。
其实可以先预处理出每个数的最小的质因子,然后简单的质因数分解。
容易发现一个结论是,我们只关注质因数次方总和恰好为 2 的合数。
所以总复杂度就是 $O(n * (\frac{log a_i}{log log a_i})^2)$ 的。