• LeetCode 235. 二叉搜索树的最近公共祖先


    235. 二叉搜索树的最近公共祖先

    题目描述

    给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先。

    百度百科中最近公共祖先的定义为:“对于有根树 T 的两个结点 p、q,最近公共祖先表示为一个结点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖先)。”

    示例

    例如,给定如下二叉搜索树: root = [6,2,8,0,4,7,9,null,null,3,5]

    示例 1:

    输入: root = [6,2,8,0,4,7,9,null,null,3,5], p = 2, q = 8
    输出: 6 
    解释: 节点 2 和节点 8 的最近公共祖先是 6。
    

    示例 2:

    输入: root = [6,2,8,0,4,7,9,null,null,3,5], p = 2, q = 4
    输出: 2
    解释: 节点 2 和节点 4 的最近公共祖先是 2, 因为根据定义最近公共祖先节点可以为节点本身。
    

    思路

    排序二叉树的特性,如果 root 的值同时大于 p 的值和 q 的值,则两个节点的公共祖先在左子树上;如果 root 的值同时小于 p 的值和 q 的值,则两个节点的公共祖先在右子树上;若没有达到同时小于或者大小,此时 p 和 q 分别在 root 的左右子树上,那么 root 为 p 和 q 的公共祖先。

    递归写法:

    class Solution(object):
        def lowestCommonAncestor(self, root, p, q):
            """
            :type root: TreeNode
            :type p: TreeNode
            :type q: TreeNode
            :rtype: TreeNode
            """
            if p.val < root.val > q.val:
                return self.lowestCommonAncestor(root.left, p, q)
    
            if p.val > root.val < q.val:
                return self.lowestCommonAncestor(root.right, p, q)
    
            return root
    

    非递归写法:

    class Solution(object):
        def lowestCommonAncestor(self, root, p, q):
            """
            :type root: TreeNode
            :type p: TreeNode
            :type q: TreeNode
            :rtype: TreeNode
            """
            while root:
                if p.val < root.val > q.val:
                    root = root.left
                elif p.val > root.val < q.val:
                    root = root.right
                else:
                    return root
    

    GitHub地址:https://github.com/protea-ban/LeetCode

  • 相关阅读:
    06.数组模拟栈-简易计算器
    05.单向环形链表应用 -- 约瑟夫环
    02.数组模拟环形队列
    01.稀疏矩阵与二维数组相互转化
    大数字相乘
    13.打包发布
    悦苗园公益活动
    程序猿打招自己的电子图书馆
    【技能】提高网站可用性
    【微信技能】如何通过微信号知道对方微信的二维码
  • 原文地址:https://www.cnblogs.com/banshaohuan/p/11447049.html
Copyright © 2020-2023  润新知