#aBC350G. [ABC350G] Mediator

[ABC350G] Mediator

AT_abc350_g [ABC350G] Mediator

题目描述

请注意特殊的输入格式。同时,请注意内存限制比通常更小。

有一个包含 NN 个顶点 1,2,,N1,2,\dots,N 的无向图,初始时没有任何边。
请对该图处理以下 QQ 个查询。

1 uu vv

类型 11:在顶点 uu 和顶点 vv 之间添加一条边。
在添加边之前,uuvv 属于不同的连通分量(也就是说,图始终是一片森林)。

2 uu vv

类型 22:如果存在同时与顶点 uu 和顶点 vv 相邻的顶点,则输出其编号,否则输出 00
由于图始终是一片森林,可以证明对于该查询的答案是唯一的。

但是,上述查询是经过加密后给出的。
原始查询由 33 个整数 A,B,CA,B,C 定义,基于此给出加密后的查询 a,b,ca,b,c
对于类型 22 的查询,第 kk 个(从前往后数)查询的答案记为 XkX_k。此外,定义 k=0k=0Xk=0X_k=0
请根据给定的 a,b,ca,b,c 按如下方式解密得到 A,B,CA,B,C

  • 设在该查询之前已经给出的类型 22 查询的个数为 ll(不包括当前查询)。此时,按如下方式解密:
    • $A = 1 + (((a \times (1+X_l)) \bmod 998244353) \bmod 2)$
    • $B = 1 + (((b \times (1+X_l)) \bmod 998244353) \bmod N)$
    • $C = 1 + (((c \times (1+X_l)) \bmod 998244353) \bmod N)$

输入格式

输入以如下格式从标准输入给出。
其中,Queryi\rm{Query}_i 表示第 ii 个查询。

NN QQ
Query1\rm{Query}_1
Query2\rm{Query}_2
\vdots
QueryQ\rm{Query}_Q

输出格式

设类型 22 的查询总共有 kk 个,请输出 kk 行。
其中第 ii 行输出第 ii 个类型 22 查询的答案。

输入输出样例 #1

输入 #1

6 12
143209915 123840720 97293110
89822758 207184717 689046893
67757230 270920641 26993265
952858464 221010240 871605818
730183361 147726243 445163345
963432357 295317852 195433903
120904472 106195318 615645575
817920568 27584394 770578609
38727673 250957656 506822697
139174867 566158852 412971999
205467538 606353836 855642999
159292205 319166257 51234344

输出 #1

0
2
0
2
6
0
1

输入输出样例 #2

输入 #2

2 1
377373366 41280240 33617925

输出 #2


说明/提示

限制

  • 所有输入均为整数。
  • 2N1052 \leq N \leq 10^5
  • 1Q1051 \leq Q \leq 10^5
  • 1u<vN1 \leq u < v \leq N
  • 0a,b,c<9982443530 \leq a,b,c < 998244353

样例解释 1

将所有查询解密后,输入如下:

6 12
2 1 3
1 2 6
1 2 4
1 1 3
2 4 6
2 1 4
1 5 6
1 1 2
2 1 4
2 2 5
2 3 4
2 2 3

对于该输入,图有 66 个顶点,包含 1212 个查询。

  • 11 个查询为 2 1 3
    顶点 11 和顶点 33 没有共同相邻的顶点,输出 00
  • 22 个查询为 1 2 6
    在顶点 22 和顶点 66 之间添加一条边。
  • 33 个查询为 1 2 4
    在顶点 22 和顶点 44 之间添加一条边。
  • 44 个查询为 1 1 3
    在顶点 11 和顶点 33 之间添加一条边。
  • 55 个查询为 2 4 6
    顶点 44 和顶点 66 的共同相邻顶点为顶点 22
  • 66 个查询为 2 1 4
    顶点 11 和顶点 44 没有共同相邻顶点,输出 00
  • 77 个查询为 1 5 6
    在顶点 55 和顶点 66 之间添加一条边。
  • 88 个查询为 1 1 2
    在顶点 11 和顶点 22 之间添加一条边。
  • 99 个查询为 2 1 4
    顶点 11 和顶点 44 的共同相邻顶点为顶点 22
  • 1010 个查询为 2 2 5
    顶点 22 和顶点 55 的共同相邻顶点为顶点 66
  • 1111 个查询为 2 3 4
    顶点 33 和顶点 44 没有共同相邻顶点,输出 00
  • 1212 个查询为 2 2 3
    顶点 22 和顶点 33 的共同相邻顶点为顶点 11

样例解释 2

也可能出现输出为空的情况。

由 ChatGPT 4.1 翻译