307963: CF1442E. Black, White and Grey Tree

Memory Limit:512 MB Time Limit:2 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

Black, White and Grey Tree

题意翻译

给一棵树,每个点是灰色(0),白色(1)或者黑色(2)。你每次可以选择一个连通块,然后在这个连通块里面选择一些点,把它们和它们所连的边删去。你不能同时选择黑点和白点。求删完整棵树的最小操作次数。

题目描述

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 $ t $ ( $ 1 \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 $ n $ ( $ 1 \le n \le 200\,000 $ ): the number of vertices in the tree. The second line of each test case contains $ n $ integers $ a_v $ ( $ 0 \le a_v \le 2 $ ): colours of vertices. Gray vertices have $ a_v=0 $ , white have $ a_v=1 $ , black have $ a_v=2 $ . Each of the next $ n-1 $ lines contains two integers $ u, v $ ( $ 1 \le u, v \le n $ ): tree edges. The sum of all $ n $ throughout the test is guaranteed to not exceed $ 200\,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

说明

![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1442E/5c7fc65a67c993efea0c5b8d456685a03459e620.png) In the first test case, both vertices are white, so you can remove them at the same time. ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1442E/7fcb0fe30316c209a4dd5c5ea57299d9714ea871.png) 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. ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1442E/a704bd67a9d5c0bd1cf54c65c7d130fa609e7e75.png) 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. ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1442E/67b7bb063d112a8f54a5b9ef736683e86b82ea81.png) 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.

Input

题意翻译

给一棵树,每个点是灰色(0),白色(1)或者黑色(2)。你每次可以选择一个连通块,然后在这个连通块里面选择一些点,把它们和它们所连的边删去。你不能同时选择黑点和白点。求删完整棵树的最小操作次数。

加入题单

上一题 下一题 算法标签: