1.문제
Given the root node of a binary search tree and two integers low and high, return the sum of values of all nodes with a value in the inclusive range [low, high].
이진 트리가 주어질 때 [low , high] 범위에 속하는 value 값을 가지는 노드들의 총 value 합계를 리턴하는 문제이다.
Example 1

Input: root = [10,5,15,3,7,null,18], low = 7, high = 15
Output: 32
Explanation: Nodes 7, 10, and 15 are in the range [7, 15]. 7 + 10 + 15 = 32.
Example 2

Input: root = [10,5,15,3,7,13,18,1,null,6], low = 6, high = 10
Output: 23
Explanation: Nodes 6, 7, and 10 are in the range [6, 10]. 6 + 7 + 10 = 23.
Constraints:
- The number of nodes in the tree is in the range [1, 2 * 104].
- 1 <= Node.val <= 105
- 1 <= low <= high <= 105
- All Node.val are unique.
2.풀이
- 노드를 순회하면서 value 값이 범위안에 포함되는지 체크한다.
- 포함된다면 sum에 더해준다.
/**
* Definition for a binary tree node.
* function TreeNode(val, left, right) {
* this.val = (val===undefined ? 0 : val)
* this.left = (left===undefined ? null : left)
* this.right = (right===undefined ? null : right)
* }
*/
/**
* @param {TreeNode} root
* @param {number} low
* @param {number} high
* @return {number}
*/
const rangeSumBST = function(root, low, high) {
let sum = 0;
const helper = (node) => {
if(node) {
helper(node.left) // 왼쪽자식
if(node.val <= high && node.val >= low) {
sum+= node.val;
}
helper(node.right) // 오른쪽 자식
}
}
helper(root);
return sum
};
3.결과
