[GESP202406 八级] 最远点对

普及+/提高 GESP 八级 真题

题目描述

小杨有一棵包含 $n$ 个节点的树,这棵树上的任意一个节点要么是白色,要么是黑色。

小杨想知道相距最远的一对不同颜色节点的距离是多少。

输入格式

第一行包含一个正整数 $n$,代表树的节点数。

第二行包含 $n$ 个非负整数 $a_1,a_2,\cdots,a_n$(对于所有的 $1\le i\le n$,均有 $a_i$ 等于 $0$ 或 $1$),其中如果 $a_i=0$,则节点 $i$ 的颜色为白色;如果 $a_i=1$,则节点 $i$ 的颜色为黑色。

之后 $(n-1)$ 行,每行包含两个正整数 $x_i,y_i$,代表存在一条连接节点 $x_i$ 和 $y_i$ 的边。

保证输入的树中存在不同颜色的点。

输出格式

输出一个整数,代表相距最远的一对不同颜色节点的距离。

数据范围

样例解释

相距最远的不同颜色的一对节点为节点 $2$ 和 $5$。

数据范围

本题采用捆绑测试。

子任务编号 得分 $n$ $a_i$ 特殊条件
$1$ $30$ $\le 10^5$ $0\le a_i\le 1$ 树的形态为一条链
$2$ $30$ $\le 10^3$ $0\le a_i\le 1$
$3$ $40$ $\le 10^5$ $0\le a_i\le 1$

对于全部数据,保证有 $1\le n\le 10^5$,$0\le a_i\le 1$。

样例输入 1

5
0 1 0 1 0
1 2
1 3
3 4
3 5

样例输出 1

3
时间限制: 1000ms
内存限制: 256MB
通过率: 0.0%
提交数: 0

设置

导航栏小工具

时钟
显示实时时钟(默认组件)
📝
代码粘贴板
快速创建和分享代码片段