问题
给定一个二叉树,找到最长的路径,这个路径中的每个节点具有相同值。 这条路径可以经过也可以不经过根节点。
注意: 两个节点之间的路径长度由它们之间的边数表示。
示例 1:
输入:
graph TD A[5] --> B[4] A --> C[5] B --> D[1] B --> E[1] C --> F[ ] C --> G[5] style F fill:transparent,stroke:transparent
输出
示例 2:
输入:
graph TD A[1] --> B[4] A --> C[5] B --> D[4] B --> E[4] C --> F[ ] C --> G[5] style F fill:transparent,stroke:transparent
输出: 注意: 给定的二叉树不超过个结点。 树的高度不超过。
解法
基本想法就是深度优先遍历。遍历时,判断左右儿子的值与自己的值是否相等,相等则result++,否则置为0即可。没有什么难度。
代码
java
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
private int result = 0;
public int longestUnivaluePath(TreeNode root) {
if (root != null) {
dfs(root);
}
return result;
}
private int dfs(TreeNode root) {
if (root ==null) {
return 0;
}
//计算左子树的同值路径
int left = dfs(root.left);
//判断左儿子与自己的值是否相等,相等则++ 否则置为0
if (root.left == null || root.val !=root.left.val) {
left = 0;
} else {
left ++;
}
//计算右子树的同值路径
int right = dfs(root.right);
//同左儿子的判断
if (root.right == null || root.val !=root.right.val) {
right = 0;
} else {
right ++;
}
//需要注意的是这里的max为left+right与result的判断。
result = Math.max(left + right,result);
return Math.max(left, right);
}
}