A90395.「BJOI2018」二进制

省选/NOI-

通过率:0%

时间限制:1.00s

内存限制:512MB

题目描述

pupil 发现对于一个十进制数,无论怎么将其的数字重新排列,均不影响其是不是 33 的倍数。他想研究对于二进制,是否也有类似的性质。
于是他生成了一个长为 nn 的二进制串,希望你对于这个二进制串的一个子区间,能求出其有多少位置不同的连续子串,满足在重新排列后(可包含前导 00)是一个 33 的倍数。两个位置不同的子区间指开始位置不同或结束位置不同。
由于他想尝试尽量多的情况,他有时会修改串中的一个位置,并且会进行多次询问。

输入格式

输入第一行包含一个正整数 nn,表示二进制数的长度。

之后一行 nn 个空格隔开的整数,保证均是 0011,表示该二进制串。

之后一行一个整数 mm,表示询问和修改的总次数。

之后 mm 行每行为 1 i1\ i,表示 pupil 修改了串的第 ii 个位置(00 变成 1111 变成 00 ),或 2 l r2\ l\ r,表示 pupil 询问的子区间是 [l,r][l,r]

串的下标从 11 开始。

输出格式

对于每次询问,输出一行一个整数表示对应该询问的结果。

输入输出样例

  • 输入#1

    4
    1 0 1 0
    3
    2 1 3
    1 3
    2 3 4

    输出#1

    2
    3

说明/提示

对于 20%20\% 的数据,1n,m1001 \leq n,m \leq 100

对于 50%50\% 的数据,1n,m50001 \leq n,m \leq 5000

对于 100%100\% 的数据,1n,m1000001 \leq n,m \leq 100000lrl \leq r

首页