[GESP202406 七级] 黑白翻转

GESP编程共123题,本题是整站第1422题,已经有人完成了本题,加油!

题目描述

小杨有一棵包含 n 个节点的树,这棵树上的任意一个节点要么是白色,要么是黑色。小杨认为一棵树是美丽树当且仅当在删除所有白色节点之后,剩余节点仍然组成一棵树。

小杨每次操作可以选择一个白色节点将它的颜色变为黑色,他想知道自己最少要执行多少次操作可以使得这棵树变为美丽树。

输入格式

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

第二行包含 n 个非负整数 a1​,a2​,…,an​,其中如果 ai​=0,则节点 i 的颜色为白色,否则为黑色。

之后 n−1 行,每行包含两个正整数 xi​,yi​,代表存在一条连接节点 xi​ 和 yi​ 的边。

输出格式

输出一个整数,代表最少执行的操作次数。

输入输出样例

输入 #1

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

输出 #1

2

说明/提示

样例解释

将节点 1 和 3 变为黑色即可使这棵树变为美丽树,此时删除白色节点 5,剩余黑色节点仍然组成一棵树。

数据范围

子任务编号 数据点占比 n ai​ 特殊条件
1 30% ≤10^5 0≤ai​≤1 树的形态为一条链
2 30% ≤10^5 0≤ai​≤1 只有两个节点颜色为黑色
3 40% ≤10^5 0≤ai​≤1  

对于全部数据,保证有 1≤n≤10^5,0≤ai​≤1。

别灰心,再试一次!

真题解析

【题目大意】

给定一棵树,节点的颜色为白色或黑色,要求将尽量少的白点染为黑点,满足去掉所有的白点后,剩余的黑点依然构成一棵树(n≤105)

【解题思路】

我们考虑一个树的哪些节点删除后,依然为一棵树。显然是所有叶子节点。在把所有叶子节点删去后,新的树的叶子节点依然可以继续删除。以此类推。也就是说,对于一个白点u,如果以u为根的子树中不存在黑点的话,那么这个白点就可以被删除,否则该白点需要被染为黑点,只需要一遍深度优先搜索,最终答案为n-黑色节点数量-以u为根的子树中不存在黑点的节点数量。还有一个特殊情况,即根节点也可能可以删除,解决方法是钦定一个黑色节点为根。

参考程序

本站题目仅供学习,GESP版权归CCF所有,如有侵权请联系删除。站长陈老师QQ及微信:208234。