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

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

题目描述

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

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

从前有三堆集合分别是 {Ai},{Bi},{Ci} \{ A_i \}, \{ B_i \}, \{ C_i \} 我们认为 $ B_i = (\mathop{\cap}\limits_{j \in A_i} B_j) \cup C_i $ 而 Ai A_i 里的元素一定小于 i i 任意时刻两个不同的 C C 集合的交集为空,现在神告诉你 A A 集合以及 C C 集合的大小,你能告诉他对于我的询问集合 S S iSBi |\mathop{\cup}\limits_{i \in S} B_i| 是多少么。

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

  1. 给定集合 A A ,令 n n 加一,多了个新的 An A_n Bn B_n Cn C_n 的大小为 k k
  2. Ci C_i 的大小改成为 k k
  3. 询问集合 S S

输入格式

第一行一个正整数 m m 表示操作总数,接下来 m m 行每行一个操作。
如果是 1 号操作,格式为 Add t \texttt{Add t} 后跟 t t 个整数,t t 表示 An A_n 的大小,t t 个整数表示集合 An A_n
如果是 2 号操作,格式为 Update i k \texttt{Update i k}
如果是 3 号操作,格式为 Query t \texttt{Query t} 后跟 t t 个整数,含义同上。

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

输出格式

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

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

数据范围与提示

n n 表示插入数量,用 q q 表示询问数量。

对于 20% 20\% 的数据,满足 n,q50 n, q \leq 50 ,Update 操作数量为 0 0 A A 集合和询问集合总大小 700 \leq 700
对于 40% 40\% 的数据,满足 n,q1000 n, q \leq 1000 ,Update 操作数量为 0 0 A A 集合和询问集合总大小 20000 \leq 20000
对于 100% 100\% 的数据,满足 n200000,q100000 n \leq 200000, q \leq 100000 ,Update 操作数量 100000 \leq 100000 A A 集合和询问集合总大小 600000;k1000 \leq 600000; k \leq 1000