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。