[hihocoder#1050 : 树中的最长路] 两种树形DP方法求树的最长路
方法一:以树上任意一个节点为根节点出发求出他子树的最长距离,那么距离最大的那个节点就必然是最长路的一个端点。然后以这个端点为根节点再DFS一次就可以求出答案了。需要DFS两次。
方法二:这个思路就是按照hihocoder 的提示思路一样,取转折点,从任意一个节点为根节点出发,遍历整个树,求出每个节点所在子树到其本身的最长路和次长路。然后,答案就是最长路+次长路了。
/**
* 方法一:两次DFS求端点
*/
#include <set>
#include <stack>
#include <queue>
#include <cmath>
#include <cstdio>
#include <string>
#include <cstring&