Gravatar
LikableP
积分:1891
提交:416 / 1100

Pro4277  [THUPC 2025 pre] 好成绩

官方题解。来源:清华大学学生算法协会仓库

CRT或是简单枚举即可得到答案 $83$


2026-01-30 20:21:40    
我有话要说
Gravatar
LikableP
积分:1891
提交:416 / 1100

【题目描述】

小 W 有一棵 $n$ 个节点的树,树上的每一条边可能是轻边或者重边。接下来你需要对树进行 $m$ 次操作,在所有操作开始前,树上所有边都是轻边。操作有以下两种:

  1. 给定两个点 $a$ 和 $b$,首先对于 $a$ 到 $b$ 路径上的所有点 $x$(包含 $a$ 和 $b$),你要将与 $x$ 相连的所有边变为轻边。然后再将 $a$ 到 $b$ 路径上包含的所有边变为重边。
  2. 给定两个点 $a$ 和 $b$,你需要计算当前 $a$ 到 $b$ 的路径一共包含多少条重边。

【输入格式】

本题有多组数据,输入数据第一行一个正整数 $T$,表示数据组数。对于每组数据:

第一行包含两个整数 $n$ 和 $m$,其中 $n$ 表示节点数量,$m$ 表示操作数量。

接下来 $n-1$ 行,每行包含两个整数 $u, v$,表示树上的一条边。

接下来 $m$ 行,每行包含三个整数 ${op}_i,a_i,b_i$,描述一个操作。其中 ${op}_i = 1$ 表示第 $1$ 类操作,${op}_i = 2$ 表示第 2 类操作。

数据保证 $a_i \neq b_i$

【输出格式】

对于每一次第 $2$ 类操作,输出一行一个整数表示答案。

【样例输入】

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$ 次操作后,重边有:$(1, 3), (3, 6), (6, 7)$。

第 $2$ 次操作,包含的重边有:$(1, 3)$。

第 $3$ 次操作,包含的重边有:$(1, 3), (3, 6), (6, 7)$。

第 $4$ 次操作,首先 $(1, 3), (3, 6)$ 变为轻边,之后 $(1, 3), (3, 5)$ 变为重边。

第 $5$ 次操作,包含的重边有:$(1, 3), (6, 7)$。

第 $6$ 次操作,首先 $(1, 3)$ 变为轻边,之后 $(1, 2)$ 变为重边。

第 $7$ 次操作,包含的重边有:$(6, 7)$。

【其他输入输出样例】

样例下载

注意:

  1. 样例 2 约束与 3-6 一致
  2. 样例 3 约束与 9-10 一致
  3. 样例 4 约束与 11-14 一致
  4. 样例 5 约束与 17-20 一致

【数据规模与约定】

测试点编号 $n,m \leq$ 特殊性质
$1-2$ $10$
$3-6$ $5000$
$7-8$ $10^5$ $A, B$
$9-10$ $A$
$11-14$ $B$
$15-16$ $2 \times 10^4$
$17-20$ $10^5$

特殊性质 $A$:树的形态是一条链

特殊性质 $B$:第 $2$ 类操作给出的 $a_i,b_i$ 之间有边直接相连

【题目来源】

NOI2021 Day1 Task1


2026-02-25 17:26:59    
Gravatar
LikableP
积分:1891
提交:416 / 1100

$\newcommand{\binom}[2]{{#1 \choose #2}}$

$\binom{n+2-k+2i}{m+5}$


2026-02-25 20:59:47    
Gravatar
LikableP
积分:1891
提交:416 / 1100

$\require{mhchem}$

$\ce{2KMnO4 ->[点燃][] K2MnO4 + MnO2 + O2 ^}$


2026-02-27 15:39:00    
Gravatar
ChenBp
积分:1090
提交:206 / 546
123

2026-02-28 10:15:31