luogu#P4428. [BJOI2018] 二进制

    ID: 8455 远端评测题 2000ms 500MiB 尝试: 0 已通过: 0 难度: 7 上传者: 标签>2018线段树各省省选树状数组北京O2优化构造

[BJOI2018] 二进制

题目描述

pupil 发现对于一个十进制数,无论怎么将其的数字重新排列,均不影响其是不是33 的倍数。他想研究对于二进制,是否也有类似的性质。

于是他生成了一个长为nn 的二进制串,希望你对于这个二进制串的一个子区间,能求出其有多少位置不同的连续子串,满足在重新排列后(可包含前导00)是一个33 的倍数。

两个位置不同的子区间指开始位置不同或结束位置不同。

由于他想尝试尽量多的情况,他有时会修改串中的一个位置,并且会进行多次询问。

输入格式

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

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

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

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

串的下标从11 开始。

输出格式

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

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

提示

###样例解释

对于第一个询问,区间[2,2][2,2] 只有数字00,是33 的倍数,区间[1,3][1,3] 可以重排成011(2)=3(10)011_{(2)} = 3_{(10)},是33 的倍数,其他区间均不能重排成33 的倍数。

对于第二个询问,全部三个区间均能重排成33 的倍数(注意0000 也是合法的)。

###数据范围

对于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