#P0225. 连通块中点的数量

连通块中点的数量

题目描述

给定一个包含 nn 个点(编号为 11nn)的无向图,初始时图中没有边。

现在要进行 mm个 操作,操作共有三种。

  1. C a b,在点 aa 和点 bb 之间连一条边,aabb 可能相等。
  2. Q1 a b,询问点 aa 和点 bb 是否在同一个连通块中,aabb 可能相等;
  3. Q2 a,询问点 aa 所在连通块中点的数量。

输入格式

第一行输入整数 nnmm

接下来 mm 行,每行包含一个操作指令,指令为 C a bQ1 a bQ2 a 中的一种。

输出格式

对于每个询问指令 Q1 a b,如果 aabb 在同一个连通块中,则输出 Yes,否则输出 No

对于每个询问指令 Q2 a,输出一个整数表示点 a 所在连通块中点的数量。

每个结果占一行。

数据范围

1n,m105.1≤n,m≤10^5.

输入样例:

3 5
Q2 1
Q2 2
C 1 3
Q1 2 2
Q2 3

输出样例:

1
1
Yes
2