#P51487. 「NOI2021」轻重边
「NOI2021」轻重边
题目描述
小 W 有一棵 个结点的树,树上的每一条边可能是轻边或者重边。接下来你需要对树进行 次操作,在所有操作开始前,树上所有边都是轻边。操作有以下两种:
- 给定两个点 和 ,首先对于 到 路径上的所有点 (包含 和 ),你要将与 相连的所有边变为轻边。然后再将 到 路径上包含的所有边变为重边。
- 给定两个点 和 ,你需要计算当前 到 的路径上一共包含多少条重边。
输入格式
从文件 edge.in
中读入数据。
本题有多组数据,输入数据第一行一个正整数 ,表示数据组数。对于每组数据: 第一行包含两个整数 和 ,其中 表示结点数量, 表示操作数量。
接下来 行,每行包含两个整数 ,表示树上的一条边。
接下来 行,每行包含三个整数 ,描述一个操作,其中 表示第 类操作, 表示第 类操作。
数据保证 。
输出格式
输出到文件 edge.out
中。
对于每一次第 类操作,输出一行一个整数表示答案。
样例 1
1
7 7
1 2
1 3
3 4
3 5
3 6
6 7
1 1 7
2 1 4
2 2 7
1 1 5
2 2 7
1 2 1
2 1 7
1
3
2
1
第 1 次操作后,重边有:,,。
第 2 次操作,包含的重边有:。
第 3 次操作,包含的重边有:,,。
第 4 次操作,首先 , 变为轻边,之后 , 变为重边。
第 5 次操作,包含的重边有:,。
第 6 次操作,首先 变为轻边,之后 变为重边。
第 7 次操作,包含的重边有:。
样例 2
见附加文件的 edge/edge2.in
与 edge/edge2.ans
该样例约束与测试点 3 ∼ 6 一致。
样例 3
见附加文件的 edge/edge3.in
与 edge/edge3.ans
该样例约束与测试点 9 ∼ 10 一致。
样例 4
见附加文件的 edge/edge4.in
与 edge/edge4.ans
该样例约束与测试点 11 ∼ 14 一致。
样例 5
见附加文件的 edge/edge5.in
与 edge/edge5.ans
该样例约束与测试点 17 ∼ 20 一致。
测试点约束
对于所有测试数据,有 。
测试点编号 | 特殊性质 | |
---|---|---|
1~2 | 10 | 无 |
3~6 | 5000 | |
7~8 | A, B | |
9~10 | A | |
11~14 | B | |
15~16 | 无 | |
17~20 |
特殊性质 A:树的形态是一条链。
特殊性质 B:第 类操作给出的 和 之间有边直接相连