Subproblem-based Approach for Resolving Max Value on Trees
int maxDiameter = 0;
public int diameterOfBinaryTree(TreeNode root) {
maxDepth(root);
return maxDiameter;
}
private int maxDepth(TreeNode root) {
if (root == null) {
return 0;
}
int leftMaxDepth = maxDepth(root.left);
int rightMaxDepth = maxDepth(root.right);
maxDiameter = Math.max(maxDiameter, leftMaxDepth + rightMaxDepth);
return Math.max(leftMaxDepth, rightMaxDepth) + 1;
}Last updated