LeetCode Solutions
637. Average of Levels in Binary Tree
Time: Space:
class Solution {
public:
vector<double> averageOfLevels(TreeNode* root) {
vector<double> ans;
queue<TreeNode*> q{{root}};
while (!q.empty()) {
long sum = 0;
const int size = q.size();
for (int i = 0; i < size; ++i) {
TreeNode* node = q.front();
q.pop();
sum += node->val;
if (node->left)
q.push(node->left);
if (node->right)
q.push(node->right);
}
ans.push_back(sum / (double)size);
}
return ans;
}
};
class Solution {
public List<Double> averageOfLevels(TreeNode root) {
List<Double> ans = new ArrayList<>();
Queue<TreeNode> q = new ArrayDeque<>(Arrays.asList(root));
while (!q.isEmpty()) {
long sum = 0;
final int size = q.size();
for (int i = 0; i < size; ++i) {
TreeNode node = q.poll();
sum += node.val;
if (node.left != null)
q.offer(node.left);
if (node.right != null)
q.offer(node.right);
}
ans.add(sum / (double) size);
}
return ans;
}
}