[关闭]
@Cyani 2021-03-02T07:43:26.000000Z 字数 926 阅读 886

XJOI 省选训练 6

xza

OI


Water Distribution

https://www.cnblogs.com/yuanquming/p/11508861.html

E 题

Modern Painting

https://www.cnblogs.com/penth/p/10263903.html

注: 以上两题均选自 AtCoder CODE FESTIVAL, 该系列比赛的题目质量较高,有兴趣的同学可以尝试去多做做.

Xor Sum

建议参考官方题解.

问题需要求的是 “最大值最小”,可以想到二分答案 ,变成判定性问题。

XOR 运算的每一位是独立的,由此我们先独立地考虑每一位。假设第 位有 个数为 ,那么 变成限制所有 的奇偶性。

的第 位(如果 是奇数先特判),可以发现 一组合法的初始解。同时,所有的解可以通过不断操作 「 减二, 加四」来得到。

加下来的方向可能也只有按数位从高到低 DP 了。有了 的限制之后,我们让状态的第二维为「当前有多少个 卡到 的上界」,称其为 “自由位”。设 为:当前考虑第 位,有 卡到上界,最少需要多少进位(也即当前位操作数量)。可以做到关于 的多项式复杂度。

考虑缩小 的状态数量。一个重要的性质是,如果「当前 ,自由位的数量至少为 ,同时不需要进位」,那么 一定可行。这是因为 的初始解 ,一旦有 个数成为自由位,可以令后面的其他位都是 ,由这 个数字自由调整。

设之前退下来的位加上当前的初始解为 ,也即当前位需要的 的个数(可以继续往后退)。如果当前 ,那么只能继续往后退。接下来,如果 并且 ,直接返回 true(由前一段所述)。否则继续枚举 ,表示新的自由位个数。继续观察可以发现一个更重要的性质:当 的时候,如果 显然是更不优的(由于奇偶性的限制, 的转移是必要的),当 足够大的时候,我们最优化的目标只有 需要的进位最少

所以需要考虑的 的上界只有 ... 由此我们得到了一个 的做法。

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注