给定一一个二叉树,您需要计算树的直径长度。树的直径是树上任意两个节点之间最长路径的长度。这条路径可能穿过根节点。 实现函数diameterOfBinaryTree(TreeNode root), 返回树的直径长度。 示例: 输入: 输出: 3 解释:树的直径为路径[4,2,1,3]或[5,2,1,3]的长度,均为3。 要求: 请使用ava语言实现函数diameterOfBinaryTree(TreeNode root)。 提示: 1.树的节点数不超过10^4。 2.每个节点的值都在[-1000, 1000]之间。
时间: 2024-03-20 14:38:35 浏览: 59
好的,针对您的问题,以下是实现 `diameterOfBinaryTree` 函数的代码:
```java
class Solution {
private int maxDiameter = 0;
public int diameterOfBinaryTree(TreeNode root) {
if (root == null) {
return 0;
}
calculateDepth(root);
return maxDiameter;
}
private int calculateDepth(TreeNode node) {
if (node == null) {
return 0;
}
int leftDepth = calculateDepth(node.left);
int rightDepth = calculateDepth(node.right);
maxDiameter = Math.max(maxDiameter, leftDepth + rightDepth);
return Math.max(leftDepth, rightDepth) + 1;
}
}
```
对于该问题,我们可以采用递归的方式来求解。对于每个节点,我们可以计算其左子树和右子树的深度,然后将左子树深度和右子树深度之和与当前最大直径比较,更新最大直径。最后返回该节点的深度,即左子树深度和右子树深度中的最大值加一。
在递归过程中,我们可以通过一个全局变量 `maxDiameter` 来记录当前最大直径。最终,我们只需要调用 `calculateDepth` 函数来计算每个节点的深度,并在计算过程中更新最大直径即可。
希望我的回答能够帮助到您!
阅读全文