题目链接:
题目大意:
给一棵树,m个点,一个距离d,求有多少个点A,使得A到所有的m个点距离都不超过d.
解题思路:
树形dp.
有两种方法可以解:
1、类似于树的直径的求法,先以任意一点作为树根,找到距离该点最远的m中的A点(A点一定是m个点中距离相距最远的两点的一个端点),然后以A点作为树根,依次计算各点到A点的最短距离d1[],并找到距离最远的m中的点B点,然后以B点为树根,依次找到各点到B点的距离d2[]. 最后再扫一遍,找到d1和d2都不超过d的点。这种方法求比较简单。
2、先以m中任意一点为树根,在子树中,求出每个节点到达m中的点的最大距离max1,达到max1的直接儿子pre,次大距离。然后再从该根出发,递归维护一个值从父亲过来并且不是通过该节点的最大距离。每次求儿子时判断下,是不是等于该节点的pre,如果是的话,从次大中找。
树很灵活,递归很强大。多做些树上的题。
代码:
#include #include #include #include #include #include #include #include #include