Leetcode 1780 Solution

This article provides solution to leetcode question 1780 (lowest-common-ancestor-of-a-binary-tree-ii).

https://leetcode.com/problems/lowest-common-ancestor-of-a-binary-tree-ii

Solution

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

class Solution:
    def lowestCommonAncestor(self, root: 'TreeNode', p: 'TreeNode', q: 'TreeNode') -> 'TreeNode':
        nodes = {p.val, q.val}
        
        ans = None
        def dfs(node):
            nonlocal ans
            
            if ans:
                return 0

            if not node:
                return 0
            
            cnt = int(node.val in nodes)
            cnt += dfs(node.left)
            cnt += dfs(node.right)
            
            if ans == None and cnt == len(nodes):
                ans = node
                return 0

            return cnt
        
        dfs(root)
        return ans