#L6105. 「2017 山东二轮集训 Day2」第三题

「2017 山东二轮集训 Day2」第三题

「2017 山东二轮集训 Day2」第三题

传统 3000 ms 512 MiB

3434 通过 7979 提交

题目描述

小火车觉得对生活已经没有什么好留恋的了,于是决定前往二次元去寻找真爱。

但是跨越次元是不被神所允许的,小火车决定和神进行比赛,神给了他一个题,你能帮忙解出来吗?

从前有三堆集合分别是 {Ai},{Bi},{Ci}\{ A_i \}, \{ B_i \}, \{ C_i \},我们认为

$$B_i = \left(\bigcap_{j \in A_i} B_j\right) \cup C_i $$

AiA_i 里的元素一定小于 ii,任意时刻两个不同的 CC 集合的交集为空。现在神告诉你 AA 集合以及 CC 集合的大小,你能告诉他对于我的询问集合 SS

iSBi\left|\bigcup_{i \in S} B_i\right|

是多少么。

实际上你要支持的操作如下:

  1. 给定集合 AA,令 nn 加一,多了个新的 AnA_nBnB_nCnC_n 的大小为 kk
  2. CiC_i 的大小改成为 kk
  3. 询问集合 SS

输入格式

第一行一个正整数 mm 表示操作总数,接下来 mm 行每行一个操作。

  • 如果是 1 号操作,格式为 Add t 后跟 tt 个整数,tt 表示 AnA_n 的大小,tt 个整数表示集合 AnA_n
  • 如果是 2 号操作,格式为 Update i k
  • 如果是 3 号操作,格式为 Query t 后跟 tt 个整数,含义同上。

数据保证合法。为了体现程序的在线性,1 号操作集合里的元素都需要异或上上次的答案,初值为 00(注意 tt 不需要)。

输出格式

对于每个 3 号操作输出一行一个整数表示答案。

样例

输入

4
Add 0 1
Query 1 1
Update 1 4
Query 1 1

输出

1
4

数据范围与提示

nn 表示插入数量,用 qq 表示询问数量。

  • 对于 20%20\% 的数据,满足 n,q50n, q \leq 50,Update 操作数量为 00AA 集合和询问集合总大小 700\leq 700
  • 对于 40%40\% 的数据,满足 n,q1000n, q \leq 1000,Update 操作数量为 00AA 集合和询问集合总大小 20000\leq 20000
  • 对于 100%100\% 的数据,满足 n200000,q100000n \leq 200000, q \leq 100000,Update 操作数量 100000\leq 100000AA 集合和询问集合总大小 600000\leq 600000k1000k \leq 1000