$Rabbit$ $Exercise$
$Description$
$Solution$
又是一道经典套路题。
首先考虑 $50pts$ 的做法。
可以发现跳到左边的贡献是 $2\times c_{j - 1} - c_j$ ,右边的贡献 $2\times c_{j + 1} - c_j$ ,所以期望就是
$$
\frac{(2 \times c_{j - 1} + 2 \times c_{j + 1} - 2 \times c_j)}{2}
$$
即
$$
c_{j - 1} + c_{j + 1} - c_j
$$
所以暴力就是做 $mk$ 次这个东西即可。
然后考虑正解。
此时,就要用到一种经典套路。
我们考虑先做一次差分,设
$$
f_i = a_i - a_{i - 1}
$$
然后我们发现,把 $c_j$ 插到 $c_{j - 1}$ 与 $c_{j +1}$ 改变位置就相当于交换 $c_j$ 与 $c_{j + 1}$ 。
然后就非常巧妙的实现了跳来跳去的一次操作。
然后我们考虑先把每个能交换的位置都交换一次,即跳一次,相当于初始化。
之后再倍增的跳,跳完之后可以很方便的把 $a_i$ 加回去,就是每一位的答案。
为什么可以这么做呢 $?$
首先,倍增的正确性是显然的。
然后,由于我们先使用了经典套路差分来使插入操作转变成了交换操作。
所以,就巧妙地实现了题目的要求。
$Code:$
1 |
|