1 条题解

  • 0
    @ 2025-8-24 23:16:01

    自动搬运

    查看原文

    来自洛谷,原作者为

    avatar 喵仔牛奶
    黄昏再美终要黑夜。

    搬运于2025-08-24 23:16:01,当前版本为作者最后更新于2025-05-05 18:16:23,作者可能在搬运后再次修改,您可在原文处查看最新版

    自动搬运只会搬运当前题目点赞数最高的题解,您可前往洛谷题解查看更多

    以下是正文


    Solution

    考虑拆位。考虑求出按位或和为 00 的区间数,用总区间减去这些就是按位或和为 11 的区间数。

    显然,按位或和为 00 等价于区间内全部为 00。线段树维护左边和右边最长的 00 连续段长度 L,RL,R、区间内按位或和为 00 的区间数 ss、区间数反转后(0101 互换)的积 ww

    线段树合并信息 (L,R,s,w)(L,R,s,w)(L,R,s,w)(L',R',s',w') 时:

    $$\begin{cases} s''=s+s'+R'\times L\\ L''=w\times L'+L\\ R''=w'\times R+R'\\ w''=w\times w' \end{cases} $$

    由于有区间 0101 反转,还要维护区间 0101 反转后的答案。

    这样直接做是 O(nlognlogV)\mathcal O(n\log n\log V) 的,无法通过。

    考虑求的是异或和,即模 22 的结果。加法和乘法在模 22 意义下等价于按位异或、按位与。因此,将每位的线段树的信息压到一个数里面,合并时将加法改为异或、乘法改完按位与即可。

    复杂度 O(nlogn)\mathcal O(n\log n)。代码很好写,就不放了。

    • 1

    信息

    ID
    11831
    时间
    1500ms
    内存
    512MiB
    难度
    5
    标签
    递交数
    0
    已通过
    0
    上传者