2673. Make Costs of Paths Equal in a Binary Tree
2673. Make Costs of Paths Equal in a Binary Tree
Description
You are given an integer n representing the number of nodes in a perfect binary tree consisting of nodes numbered from 1 to n. The root of the tree is node 1 and each node i in the tree has two children where the left child is the node 2 * i and the right child is 2 * i + 1.
Each node in the tree also has a cost represented by a given 0-indexed integer array cost of size n where cost[i] is the cost of node i + 1. You are allowed to increment the cost of any node by 1 any number of times.
Return the minimum number of increments you need to make the cost of paths from the root to each leaf node equal.
Note :
- A perfect binary tree is a tree where each node, except the leaf nodes, has exactly 2 children.
- The cost of a path is the sum of costs of nodes in the path.
Example 1:
1 | Input: n = 7, cost = [1,5,2,2,3,3,1] |
Example 2:
1 | Input: n = 3, cost = [5,3,3] |
Constraints:
3 <= n <= 10^5n + 1is a power of2cost.length == n1 <= cost[i] <= 10^4
Hints/Notes
- 2025/04/07 Q3
- binary tree
- 0x3Fâs solution
Solution
Language: C++
1 | class Solution { |