Leetcode 1484 Solution
This article provides solution to leetcode question 1484 (linked-list-in-binary-tree)
Access this page by simply typing in "lcs 1484" in your browser address bar if you have bunnylol configured.
Leetcode Question Link
https://leetcode.com/problems/linked-list-in-binary-tree
Solution
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, val=0, next=None):
# self.val = val
# self.next = next
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, val=0, left=None, right=None):
# self.val = val
# self.left = left
# self.right = right
class Solution:
def isSubPath(self, head: ListNode, root: TreeNode) -> bool:
def validate(tree_node, list_node):
if list_node is None:
return True
if tree_node is None:
return False
if tree_node.val != list_node.val:
return False
return validate(tree_node.left, list_node.next) or validate(tree_node.right, list_node.next)
def validate_all_nodes(tree_node):
nonlocal head
if validate(tree_node, head):
return True
if tree_node is None:
return False
return validate_all_nodes(tree_node.left) or validate_all_nodes(tree_node.right)
return validate_all_nodes(root)