Leetcode 1484 Solution

This article provides solution to leetcode question 1484 (linked-list-in-binary-tree).

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)