3871 - 最远点对

题目描述

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

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

输入

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

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

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

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

输出

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

样例

输入

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

输出

3
说明

【样例解释 】

相距最远的不同颜色的一对节点为节点 25

【数据范围】

对于全部数据,保证有 1 \le n \le 10^50 \le a_i \le 1

来源

2024年GESP 6月认证C++八级真题

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


上一题 下一题