P14929 [北大集训 2025] 小丑大师的荣耀
题目描述
在小丑牌中达成成就「完美主义者 ++」后,伟大的 Balatro 贤者 Clonoth 决定考一考你对卡牌游戏的理解。
Clonoth 提出了以下问题:给定一个包含 $n$ 张卡牌的牌堆,每张卡牌的正反面各写有一个 $[1, m]$ 中的正整数。你可以选择若干张卡牌,将其正反面翻转。对于 $1 \le l \le r \le m$,若存在一种翻转方式,使得翻转后 $[l, r]$ 中每个整数 $i$ 都出现在至少一张卡牌的正面,则称区间 $[l, r]$ 是**可覆盖的**。形式化地,设第 $i$ ($1 \le i \le n$) 张卡牌的正反面上的正整数分别为 $a_{i,0}, a_{i,1}$,则 $[l, r]$ 是可覆盖的当且仅当存在一个长度为 $n$ 的 01 串 $s$,满足对于所有 $l \le i \le r$,存在 $1 \le j \le n$ 满足 $a_{j, s_j} = i$。
由于牌堆在游戏中是动态变化的,Clonoth 设计了一个动态场景。具体地,初始时牌堆为空,即 $n = 0$,接下来 Clonoth 将会进行 $q$ 次操作,每次操作是以下三种类型之一:
1. 插入卡牌:给定正整数 $x, y$ ($1 \le x, y \le m$),令 $n \leftarrow n + 1$,然后向牌堆中插入一张编号为 $n$,正面为 $x$,反面为 $y$ 的卡牌;
2. 移除卡牌:给定正整数 $p$ ($1 \le p \le n$),满足编号为 $p$ 的卡牌当前仍在牌堆中,然后从牌堆中移除该卡牌;
3. 询问:给定正整数 $s, t, u, v$ ($1 \le s \le t \le m$, $1 \le u \le v \le m$),你需要求出有多少个区间 $[l, r]$ 满足 $s \le l \le t$, $u \le r \le v$ 且 $[l, r]$ 是可覆盖的。
如果你能正确回答所有询问,Balatro 贤者 Clonoth 就会赠予你一个珍贵的护符——「小丑大师的荣耀」!
输入格式
从标准输入读入数据。
输入的第一行包含两个正整数 $m, q$,表示卡牌上的数字的范围和操作次数。
输入的第 $i+1$ ($1 \le i \le q$) 行包含若干个正整数,表示第 $i$ 次操作,其中第一个正整数 $o$ 表示第 $i$ 次操作的类型。
- 若 $o = 1$,则该行包含三个正整数 $o, x, y$,表示插入一张正面为 $x$,反面为 $y$ 的卡牌;
- 若 $o = 2$,则该行包含两个正整数 $o, p$,表示移除编号为 $p$ 的卡牌;
- 若 $o = 3$,则该行包含五个正整数 $o, s, t, u, v$,表示一次询问。
输出格式
输出到标准输出。
对于每次询问,输出一行一个非负整数,表示满足要求的区间数量。
说明/提示
### 【子任务】
对于所有测试数据,均有:
- $1 \le m, q \le 2 \times 10^5$;
- 对于每次操作,均有 $o \in \{1,2,3\}$,且给定的参数均满足【题目描述】中的限制。
| 子任务编号 | 分值 | $m, q \le$ | 特殊性质 |
|:-:|:-:|:-:|:-:|
| 1 | 30 | $2000$ | 无 |
| 2 | 10 | $2 \times 10^5$ | A |
| 3 | 10 | $2 \times 10^5$ | BC |
| 4 | 20 | $2 \times 10^5$ | B |
| 5 | 20 | $2 \times 10^5$ | C |
| 6 | 10 | $2 \times 10^5$ | 无 |
特殊性质 A:所有插入卡牌与移除卡牌的操作均在所有询问之前。
特殊性质 B:不存在移除卡牌的操作。
特殊性质 C:所有询问均满足 $s = t$ 且 $u = v$。