小杨有一棵包含 n 个节点的树,其中节点的编号从 1 到 n 。
小杨设置了 a 个好点对 {< u_1, v_1 >, < u_2, v_2 >, \ldots, < u_a, v_a >} 和 1 个坏点对 < b_u, b_v >。一个节点能够被删除,当且仅当:
如果点对中的任意一个节点被删除,其视为不连通。
小杨想知道,有多少个节点能够被删除
第一行包含两个正整数 n, a ,含义如题面所示。
之后 n - 1 行,每行包含两个正整数 x_i, y_i ,代表存在一条连接节点 x_i 和 y_i 的边。
之后 a 行,每行包含两个正整数 u_i, v_i ,代表一个好点对 < u_i, v_i > 。
最后一行包含两个正整数 b_u, b_v ,代表坏点对 < b_u, b_v > 。
输出一个正整数,代表能够删除的节点个数。
6 2 1 3 1 5 3 6 3 2 5 4 5 4 5 3 2 6
2
| 子任务编号 | 分值 | n | a |
|---|---|---|---|
| 1 | 20% | 10 | 0 |
| 2 | 20% | \leq 100 | \leq 100 |
| 3 | 60% | \leq 10^6 | \leq 10^5 |
对于全部数据,保证有 1 \leq n \leq 10^6 , 0 \leq a \leq 10^5 , u_i \neq v_i , b_u \neq b_v 。
2025年GESP 3月认证C++八级真题