파이썬 알고리즘 인터뷰 52번(리트코드 938번) Range Sum of BST
https://leetcode.com/problems/range-sum-of-bst/
# 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 rangeSumBST(self, root: Optional[TreeNode], low: int, high: int) -> int:
cnt = 0
def helper(root):
nonlocal cnt
if not root:
return
if low <= root.val <= high:
cnt += root.val
if root.val > high:
helper(root.left)
return
if root.val < low:
helper(root.right)
return
helper(root.left)
helper(root.right)
return
helper(root)
return cnt
# 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 rangeSumBST(self, root: Optional[TreeNode], low: int, high: int) -> int:
def helper(root, cnt):
if not root:
return 0
if low <= root.val <= high:
return cnt + root.val + helper(root.left, cnt) + helper(root.right, cnt)
if root.val > high:
return cnt + helper(root.left, cnt)
if root.val < low:
return cnt + helper(root.right, cnt)
return helper(root, 0)
# 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 rangeSumBST(self, root: Optional[TreeNode], low: int, high: int) -> int:
def helper(root):
if not root:
return 0
if low <= root.val <= high:
return root.val + helper(root.left) + helper(root.right)
if root.val > high:
return helper(root.left)
if root.val < low:
return helper(root.right)
return helper(root)
# 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 rangeSumBST(self, root: Optional[TreeNode], low: int, high: int) -> int:
stack = [root]
curr = 0
while stack:
node = stack.pop()
if node:
if low <= node.val <= high:
curr += node.val
if node.val > low:
stack.append(node.left)
if node.val < high:
stack.append(node.right)
return curr
stack 대신 queue를 사용하여 BFS로도 풀 수 있다.