A. 入阵曲

求每一行的前缀和,

枚举左右端点,O(n)扫下去,顺便更新桶。

维护栈清空桶中的内容。

 

 

 


 

B. 将军令

k=1,小胖守皇宫弱化版。

与小胖守皇宫比较,发现特殊性质:

点没有权值。

考虑贪心。

每次找出深度最深的点,点亮它的k级父亲。

1.点亮k级父亲比点亮它的任何一个儿子更优,因为能更多的覆盖到该子树外的节点。

2.点亮k级父亲子树以外的点,不能覆盖到深度最深的点。

综上,该贪心策略是正确的。

 

考试时想到了这个贪心策略,

然而受小胖守皇宫限制,固执地认为贪心一定不成立。

那道题已经做过去很久,已经忘记了差异点。

其实可以尝试一下贪心,打个对拍的。

 

 

 


 

C. 星空

区间翻转的修改很大,难处理。

考虑如何将区间修改为单点。

差分即可。

设$a_i$表示第$i$盏灯的初始状态,1为灭,0为亮。

设$b_i=a_i$^$a_{i+1}$,显然b的前缀和表示单点的a值。

将区间修改$(l,r)$转化为单点修改$l-1$和$r$,将两个值取反就达到了区间修改的效果。

要求的最终状态是b数列全为0。

将两个0取反为1是没有意义的。

有意义的移动是将一个1不断与0取反,直到两个1共同取反为0。

bfs处理出一些1之间的路径,对不超过2k个1之间进行状压。

复杂度为$O(2^{2k}*k^2+nmk)$

然而dp转移有一些冗余。

固定一个转移的顺序可以达到优化的效果。

每次转移第一个1,复杂度为$O(2^{2k}*k+nmk)$。