Skip to content

Commit cced2df

Browse files
authored
Create Count Nodes Equal to Average of Subtree.java
1 parent 83e7c60 commit cced2df

File tree

1 file changed

+37
-0
lines changed

1 file changed

+37
-0
lines changed
Lines changed: 37 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
/**
2+
* Definition for a binary tree node.
3+
* public class TreeNode {
4+
* int val;
5+
* TreeNode left;
6+
* TreeNode right;
7+
* TreeNode() {}
8+
* TreeNode(int val) { this.val = val; }
9+
* TreeNode(int val, TreeNode left, TreeNode right) {
10+
* this.val = val;
11+
* this.left = left;
12+
* this.right = right;
13+
* }
14+
* }
15+
*/
16+
class Solution {
17+
public int averageOfSubtree(TreeNode root) {
18+
int[] result = {0};
19+
helper(root, result);
20+
return result[0];
21+
}
22+
23+
private int[] helper(TreeNode root, int[] result) {
24+
if (root == null) {
25+
return new int[]{0, 0};
26+
}
27+
int[] left = helper(root.left, result);
28+
int[] right = helper(root.right, result);
29+
int sum = left[0] + right[0] + root.val;
30+
int numOfNodes = left[1] + right[1] + 1;
31+
int average = sum / numOfNodes;
32+
if (root.val == average) {
33+
result[0]++;
34+
}
35+
return new int[]{sum, numOfNodes};
36+
}
37+
}

0 commit comments

Comments
 (0)