236. Lowest Common Ancestor of a Binary Tree
Previous297. Serialize and Deserialize Binary TreeNext235. Lowest Common Ancestor of a Binary Search Tree
Last updated
Was this helpful?
Last updated
Was this helpful?
Given a binary tree, find the lowest common ancestor (LCA) of two given nodes in the tree.
According to the : “The lowest common ancestor is defined between two nodes v and w as the lowest node in T that has both v and w as descendants (where we allow a node to be a descendant of itself).”
For example, the lowest common ancestor (LCA) of nodes5
and1
is3
. Another example is LCA of nodes5
and4
is5
, since a node can be a descendant of itself according to the LCA definition.
Thoughts:
Recursion: for each node, there must be three cases {left, right, root} that contains CLA.
Code (C++)
Code (Python)
Special Thanks for for providing such a cool, condensed solution!