
Leetcode Problem 543: Diameter of Binary Tree
Given the root of a binary tree, return the diameter — the length of the longest path between any two nodes in the tree, measured by the number of edges. The path does not need to pass through the root.
Constraints:
export class TreeNode {
val: number
left: TreeNode | null
right: TreeNode | null
constructor(val?: number, left?: TreeNode | null, right?: TreeNode | null) {
this.val = (val === undefined ? 0 : val)
this.left = (left === undefined ? null : left)
this.right = (right === undefined ? null : right)
}
}
function diameterOfBinaryTree(root: TreeNode | null): number {
let maxDiameter = 0
function height(root: TreeNode | null): number {
if (!root) {
return 0
}
const leftHeight = height(root.left)
const rightHeight = height(root.right)
maxDiameter = Math.max(maxDiameter, leftHeight + rightHeight)
return 1 + Math.max(leftHeight, rightHeight)
}
height(root)
return maxDiameter
}