Subject address: leetcode-cn.com/problems/lo…
The title
Analysis:
Definition of ancestors: If p is in the left (right) subtree of root or p = roott, root is the ancestor of P.
Definition of the last common ancestor: Let node root be a common ancestor of nodes P and Q. If its left child node root.left and right child node root.right are not the common ancestor of p and Q, root is called the “last common ancestor”.
According to the above definition, if root is the nearest common ancestor of P and Q, it can only be one of the following:
- P and Q are in the subtree of root, and respectively in the different sides of root (i.e. in the left and right subtrees respectively).
- P = root, and q is in the left or right subtree of root;
- Q = root, and p is in the left or right subtree of root;
Consider a recursive back-order traversal of a binary tree when a node is encounteredp
或q
When to return. Traceback from bottom to top, when nodep
.q
In the noderoot
On the other side of the noderoot
Is the most recent common ancestor, then back uproot
.
Recursive analysis
1. Termination Conditions:
When over a leaf node, null is returned; If root is equal to p, q, return root.
2. Recursive work:
Enable the recursive left child node, and the return value is denoted as left; Open the recursive right child node, return value is denoted as right;
3. Return value: according to the left and right, can be expanded into four cases;
If both left and right are empty, the root subtree does not contain p and q, and null is returned. If left and right are not empty at the same time, p and Q are on the opposite side of root (on the left and right subtrees respectively), so root is the nearest common ancestor. When left is empty, right is not empty: p and q are not in the left subtree of root, return right directly. It can be divided into two cases: p and Q. One of them is in the right subtree of root, and right points to PP (suppose pp). Both p and Q nodes are in the right subtree of root, and right at this time points to the nearest common ancestor node.
4. When left is not empty, right is empty: and case 3. In the same way;
It is observed that case 1 can be combined into 3. And 4. See the code at the end of the article.
Code:
class Solution {
public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
if(root == null || root == p || root == q) return root;
TreeNode left = lowestCommonAncestor(root.left, p, q);
TreeNode right = lowestCommonAncestor(root.right, p, q);
if(left == null) return right;
if(right == null) return left;
returnroot; }}Copy the code
The expansion of cases 1., 2., 3., 4. Is written as follows.
class Solution {
public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
if(root == null || root == p || root == q) return root;
TreeNode left = lowestCommonAncestor(root.left, p, q);
TreeNode right = lowestCommonAncestor(root.right, p, q);
if(left == null && right == null) return null; / / 1.
if(left == null) return right; / / 3.
if(right == null) return left; / / 4.
return root; // 2. if(left ! = null and right ! = null)}}Copy the code