#aBC183F. [ABC183F] Confluence

[ABC183F] Confluence

AT_abc183_f [ABC183F] Confluence

题目描述

NN 名学生准备上学。第 ii 名学生属于班级 CiC_i

每位学生从自己家出发,途中会不断与其他学生汇合,一起前往学校。已经汇合的学生不会再分开。

现在给出 QQ 个查询,请按顺序处理。查询有两种类型,输入格式和内容如下:

  • 1 a b :将包含学生 aa 的集体与包含学生 bb 的集体合并(如果已经在同一集体中则什么都不做)。
  • 2 x y :询问当前与学生 xx 已经汇合在一起的所有学生(包括 xx 本人)中,属于班级 yy 的学生有多少人。

输入格式

输入通过标准输入给出,格式如下:

NN QQ C1C_1 \ldots CNC_N
Query1Query_1
\vdots
QueryQQuery_Q

输出格式

对于每个 2 x y 类型的查询,按顺序每行输出一个答案。

输入输出样例 #1

输入 #1

5 5
1 2 3 2 1
1 1 2
1 2 5
2 1 1
1 3 4
2 3 4

输出 #1

2
0

输入输出样例 #2

输入 #2

5 4
2 2 2 2 2
1 1 2
1 1 3
1 2 3
2 2 2

输出 #2

3

输入输出样例 #3

输入 #3

12 9
1 2 3 1 2 3 1 2 3 1 2 3
1 1 2
1 3 4
1 5 6
1 7 8
2 2 1
1 9 10
2 5 6
1 4 8
2 6 1

输出 #3

1
0
0

说明/提示

限制条件

  • 1N2×1051 \leq N \leq 2 \times 10^5
  • 1Q2×1051 \leq Q \leq 2 \times 10^5
  • 1Ci,a,b,x,yN1 \leq C_i, a, b, x, y \leq N
  • 对于 1 a b 查询,aba \neq b
  • 所有输入均为整数

样例解释 1

在第 33 个查询时,学生 11 已经与学生 2,52,5 汇合。学生 1,2,51,2,5 中属于班级 11 的有 22 人。在第 55 个查询时,学生 33 已经与学生 44 汇合。学生 3,43,4 中属于班级 44 的有 00 人。

样例解释 2

对于已经属于同一集体的学生,也可能会给出 1 a b 类型的查询。

由 ChatGPT 4.1 翻译