From ccd47169dbd8b46433d69f3eb9c5c51a6337a49d Mon Sep 17 00:00:00 2001 From: Pavel Karateev Date: Sun, 3 Nov 2024 19:42:50 +0100 Subject: [PATCH] re-solve "100. Same Tree" --- src/same_tree.py | 33 ++++++++------------------------- 1 file changed, 8 insertions(+), 25 deletions(-) diff --git a/src/same_tree.py b/src/same_tree.py index f4fbf5a..6b1d288 100644 --- a/src/same_tree.py +++ b/src/same_tree.py @@ -1,30 +1,13 @@ -from typing import TypeAlias - from src.utils.binary_tree import TreeNode -Stack: TypeAlias = list[TreeNode | None] - class Solution: def isSameTree(self, p: TreeNode | None, q: TreeNode | None) -> bool: - stack_p: Stack = [p] - stack_q: Stack = [q] - - while stack_p and stack_q: - node_p = stack_p.pop() - node_q = stack_q.pop() - - if node_p and node_q: - if node_p.val != node_q.val: - return False - - stack_p.append(node_p.left) - stack_p.append(node_p.right) - stack_q.append(node_q.left) - stack_q.append(node_q.right) - elif node_p is None and node_q is None: - continue - else: - return False - - return not stack_p and not stack_q + if not p and not q: + return True + elif not p or not q or p.val != q.val: + return False + else: + return self.isSameTree(p.left, q.left) and self.isSameTree( + p.right, q.right + )