[LeetCode] Range Sum of BST

준규·2022년 12월 13일

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.풀이

  1. 노드를 순회하면서 value 값이 범위안에 포함되는지 체크한다.
  2. 포함된다면 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.결과

profile
안녕하세요 :)

0개의 댓글