4690 - 割裂

题目描述

小杨有一棵包含 n 个节点的树,其中节点的编号从 1 到 n

小杨设置了 a 个好点对 {< u_1, v_1 >, < u_2, v_2 >, \ldots, < u_a, v_a >} 和 1 个坏点对 < b_u, b_v >。一个节点能够被删除,当且仅当:

  • 删除该节点后对于所有的 i (1 \leq i \leq a) ,好点对 u_i v_i 仍然连通;
  • 删除该节点后坏点对 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
120%100
220%\leq 100\leq 100
360%\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++八级真题

标签
题目参数
时间限制 1 秒
内存限制 512 MB
提交次数 30
通过人数 4
金币数量 1 枚
难度 基础


上一题 下一题