#P5222. 「泉州基地校201811D4」2.挑战书

「泉州基地校201811D4」2.挑战书

Description

【题目背景】 小 E 是一位实力强大的 OIer,经常在各类比赛中随手 AK 虐场。然而她最近秒题时遇到了 一道需要她思考 15 秒才能做出的题目,整整花了 15 倍于其他题目的时间。她认为这个问题 十分有意思,并且对其进行了一些拓展和修改以后抛给了你。你能接受小 E 的挑战吗?

【题目描述】

pip_i 表示非负整数 pp 的二进制表示中在项 2i2^i 前的系数,对于非负整数 p,qp,q ,可以定义二元 运算xnorxnor (同或)为: pp xnor\text{xnor} $q=\sum_{i=0}^M ((p_i \land q_i) \lor (\lnot (p_i \lor q_i))) \times 2^i$(在这里我们认为布尔表达式的值 false 或 true 能够直接对应于整数0或1并参与算术运算, 反之亦然; 其中 MM 为常数,本题中 MM 的取值为31)。 给定一个长度为 nn 的非负整数序列 aa,在序列的每个位置上有非负整数权值 wiw_i ,现在希望实现对该序列的以下操作:

  1. 给定区间 [l,r][l,r] 和非负整数 kk ,查询 (i=lrai×w(i))(\sum_{i=l}^r a_i \times w'(i)) xnorxnor (i=lrai)(\sum_{i=l}^r a_i) 。其中 $w'(i)=\begin{cases} w_i, if w_i \le k \\ 0 ,if w_i > k\end{cases}$

  2. 给定正整数pp 和非负整数 kk ,将 apa_p 的值修改为 kk

  3. 给定正整数pp 和非负整数 kk ,将 wpw_p 的值修改为kk

Input Format

输入的第 1 行包含两个整数 n,q n, qnn 表示序列长度,qq 表示操作次数。

接下来 1 行,包含 nn 个整数,其中第 ii 个表示 aia_i

接下来 1 行,包含 nn 个整数,其中第 ii 个表示 wiw_i

接下来 qq 行,每行包含 4 个或 3 个整数,其中第 1 个整数表示操作类型(见题目描述)。

对于第 1 种操作,接下来 3 个整数依次表示 l,r,kl,r,k ;对于第 2 或第 3 种操作,接下来 2 个整数依次表示 p,kp,k

Output Format

对于每个第 1 种操作输出一行一个整数,表示答案。

Sample

【输入输出样例 1】

输入

10 10
13 15 23 45 21 23 14 26 35 44
12 32 15 47 15 32 12 47 32 32
1 2 8 17
2 4 26
1 1 6 47
3 9 6
2 9 4
1 1 7 5
3 7 6
2 7 2
3 3 6
1 4 9 6

输出

4294966372
4294964016
4294967160
4294967229

Hint

【样例1说明】

对于第1次询问, k=17k = 17 ,此时在 [2,8][2,8] 区间内第3、第5和第7位置上的 wi17w_i \le 17 。因此答案为 $(a_3 \times w_3 + a_5 \times w_5 + a_7 \times w_7 )$ 。按照定义式计算即可得上式的值。 对于第3次询问,此时序列上的权值为w=12,32,15,47,15,32,12,47,6,32w = {12,32,15,47,15,32,12,47,6,32}k=5 k = 5 ,但不存在 wi5w_i \le 5 的位置,因此答案为 00 xnorxnor (i=17ai)(\sum_{i=1}^7 a_i)

【输入输出样例2】

见下发文件中的challenge2.inchallenge2.out

【数据范围与约定】

对于全部数据,有 1n,q1051 \le n,q \le 10^50ai,wi,k1050 \le a_i,w_i,k \le 10^51l,r,pn 1 \le l,r,p \le n 。下表中留空的位置代表该测试点在这一项目上没有特殊约定。

捕获.JPG

【提示】

\land 表示逻辑与(即布尔代数中的与运算and),¬\lnot 表示逻辑非(即布尔代数中的非运算not)。

由于本题时限较大,为节省评测时间,建议选手在程序中判断输入数据的规模并在程序会运行超时的数据点自行退出程序。