题目描述
给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。
百度百科中最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖先)。”
示例 1:
示例 2:
示例 3:
输入:root = [1,2], p = 1, q = 2
输出:1
来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/lowest-common-ancestor-of-a-binary-tree/
解题思路
本题为寻找最近公共祖先,也可以理解为,遍历到一个根结点时判断两个子节点是否都在他的孩子节点上。如果都在,就进行更深一层次的遍历,否则他递归的时候最近一次两个节点都在的根结点就是要找的最近公共祖先