[ZJOI2013] K大数查询
题目描述
你需要维护 $n$ 个可重整数集,集合的编号从 $1$ 到 $n$。
这些集合初始都是空集,有 $m$ 个操作:
- `1 l r c`:表示将 $c$ 加入到编号在 $[l,r]$ 内的集合中
- `2 l r c`:表示查询编号在 $[l,r]$ 内的集合的并集中,第 $c$ 大的数是多少。
注意可重集的并是不去除重复元素的,如 $\{1,1,4\}\cup\{5,1,4\}=\{1,1,4,5,1,4\}$。
输入输出格式
输入格式
第一行两个正整数 $n,m$,表示集合个数和操作个数。
接下来 $m$ 行,每行四个整数表示一次操作。
输出格式
对于每个 $2$ 操作,输出一行一个整数表示答案。
输入输出样例
输入样例 #1
2 5
1 1 2 1
1 1 2 2
2 1 1 2
2 1 1 1
2 1 2 3
输出样例 #1
1
2
1
说明
【样例说明】
第 $1$ 次操作在 $1,2$ 号集合中分别加入了一个 $1$。
第 $2$ 次操作在 $1,2$ 号集合中分别加入了一个 $2$。
第 $3$ 次操作查询 $1$ 号集合中第 $2$ 大的数,答案为 $1$。
第 $4$ 次操作查询 $1$ 号集合中第 $1$ 大的数,答案为 $2$。
第 $5$ 次操作查询 $1,2$ 号集合的并集 $\{1,2,1,2\}$ 中第 $3$ 大的数,答案为 $1$。
【数据范围】
$1 \le n,m \le 5\times 10^4$
$1\le l,r \le n$
$1$ 操作中 $|c|\le n$
$2$ 操作中 $1\le c < 2^{63}$,第 $c$ 大的数存在
---
$\text{upd 2023.8.23}$:新增加一组 Hack 数据。