235. Lowest Common Ancestor of a Binary Search Tree

235. Lowest Common Ancestor of a Binary Search Tree

题目:
https://leetcode.com/problems/lowest-common-ancestor-of-a-binary-search-tree/

难度 : Easy

  • 两个node,一个大于root,一个小于root,那么必定root两边,共同的ancestor是root,同时再考虑同为空的状况
  • 两个node,都比node小,到左边去寻找,那么先找到那个必定是common ancestor
  • 两个node,都比node大,类似....

AC解法

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

你可能感兴趣的:(235. Lowest Common Ancestor of a Binary Search Tree)