CF1442E.Black, White and Grey Tree

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

You are given a tree with each vertex coloured white, black or grey. You can remove elements from the tree by selecting a subset of vertices in a single connected component and removing them and their adjacent edges from the graph. The only restriction is that you are not allowed to select a subset containing a white and a black vertex at once.

What is the minimum number of removals necessary to remove all vertices from the tree?

输入格式

Each test contains multiple test cases. The first line contains an integer tt ( 1t1000001 \le t \le 100\,000 ), denoting the number of test cases, followed by a description of the test cases.

The first line of each test case contains an integer nn ( 1n2000001 \le n \le 200\,000 ): the number of vertices in the tree.

The second line of each test case contains nn integers ava_v ( 0av20 \le a_v \le 2 ): colours of vertices. Gray vertices have av=0a_v=0 , white have av=1a_v=1 , black have av=2a_v=2 .

Each of the next n1n-1 lines contains two integers u,vu, v ( 1u,vn1 \le u, v \le n ): tree edges.

The sum of all nn throughout the test is guaranteed to not exceed 200000200\,000 .

输出格式

For each test case, print one integer: the minimum number of operations to solve the problem.

输入输出样例

  • 输入#1

    4
    2
    1 1
    1 2
    4
    1 2 1 2
    1 2
    2 3
    3 4
    5
    1 1 0 1 2
    1 2
    2 3
    3 4
    3 5
    8
    1 2 1 2 2 2 1 2
    1 3
    2 3
    3 4
    4 5
    5 6
    5 7
    5 8

    输出#1

    1
    3
    2
    3

说明/提示

In the first test case, both vertices are white, so you can remove them at the same time.

In the second test case, three operations are enough. First, we need to remove both black vertices (2 and 4), then separately remove vertices 1 and 3. We can't remove them together because they end up in different connectivity components after vertex 2 is removed.

In the third test case, we can remove vertices 1, 2, 3, 4 at the same time, because three of them are white and one is grey. After that, we can remove vertex 5.

In the fourth test case, three operations are enough. One of the ways to solve the problem is to remove all black vertices at once, then remove white vertex 7, and finally, remove connected white vertices 1 and 3.

首页