[GESP202412 八级] 树上移动

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

题目描述

小杨有一棵包含 n 个节点的树,其中节点的编号从 1 到 n,每个节点的颜色要么是白色要么是黑色,小杨可以任意选择节点 s 和节点 t 并从节点 s 出发移动到节点 t,移动过程中小杨不能够经过重复节点。

小杨希望自己在至多经过 k 个黑色节点的前提下,经过的总节点数尽可能多,请你帮小杨选择经过最多的节点数是多少。

输入格式

第一行包含两个正整数 n,k,代表节点数量和至多经过的黑色节点数。

第二行包含 n 个正整数 a1​,a2​,…,an​,代表节点颜色,如果 ai​=0,代表节点颜色为白色,如果 ai​=1,代表节点颜色为黑色。

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

输出格式

输出一个正整数,代表最多经过的节点数。

输入输出样例

输入 #1

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

输出 #1

3

说明/提示

子任务编号 数据点占比 n k 特殊性质
1 20% ≤100 ≤100 树的形态为一条链
2 20% ≤1000 0  
3 60% ≤1000 ≤1000  

对于全部数据,保证有 1≤n≤1000,0≤k≤1000,0≤ai​≤1。

别灰心,再试一次!

真题解析

【题目大意】给定一棵树,在至多经过k个黑色节点的前提下,经过的总节点数尽可能多。

【考纲知识点】树形DP/树上DFS

【解题思路】本题数据范围为1000,用n²算法也可以通过,从任意一个节点出发深搜,达成条件(经过的黑色节点数超过了k个)停止搜索,在搜索的过程中记录经过的总结点数,并且不断和结果值res进行比较,res记录经过的总结点数的最大值。

参考程序

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