Last updated
Last updated
# 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':
if not root:
return None
if p == root or q == root:
return root
left = self.lowestCommonAncestor(root.left, p, q)
right = self.lowestCommonAncestor(root.right, p, q)
if left and right:
return root
if not left and not right:
return None
return left or right
class Solution:
def lowestCommonAncestor(self, p: 'Node', q: 'Node') -> 'Node':
t = p
while t.parent:
t = t.parent
root = t
nodes = set([p, q])
def helper(root, nodes):
if not root:
return None
if root in nodes:
return root
left = helper(root.left, nodes)
right = helper(root.right, nodes)
if left and right:
return root
return left or right
return helper(root, nodes)
class Solution:
def lowestCommonAncestor(self, p: 'Node', q: 'Node') -> 'Node':
# 由 p 開始向上搜尋 root 節點,並且把路徑上造訪過的節點都記錄起來
# 因為最近共同祖先一定會在這個 set 裡面。
# 如果在向上找的過程中,就遇到了 q 節點,那 q 就是最近共同祖先。
t = p
visited = {t}
while t.parent:
t = t.parent
visited.add(t)
if t == q:
return q
root = t
k = q
# 由 q 開始向上搜尋,如果找到有節點已經造訪過,那那個節點就是最近共同祖先
while k.parent:
k = k.parent
if k in visited:
return k
# 這一行其實用不到,因為 root 其實一定會在造訪過的節點了。
return root
class Solution:
def lowestCommonAncestor(self, root: 'TreeNode', p: 'TreeNode', q: 'TreeNode') -> 'TreeNode':
visited = set()
nodes = set()
nodes.add(p)
nodes.add(q)
def helper(root, nodes):
visited.add(root)
if not root:
return None
left = helper(root.left, nodes)
right = helper(root.right, nodes)
if root in nodes:
return root
if left and right:
return root
return left or right
res = helper(root, nodes)
if q not in visited or p not in visited:
return None
else:
return res
# 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':
if not root:
return None
if p == root or q == root:
return root
left = self.lowestCommonAncestor(root.left, p, q)
right = self.lowestCommonAncestor(root.right, p, q)
if left and right:
return root
if not left and not right:
return None
return left or right