【每日一扣】637. 二叉树的层平均值
李彬的技术笔记
编程、投资、生活
Official Account
Difficulty: 简单
给定一个非空二叉树, 返回一个由每层节点平均值组成的数组。
示例 1:
输入:
3
/ \
9 20
/ \
15 7
输出:[3, 14.5, 11]
解释:
第 0 层的平均值是 3 , 第1层是 14.5 , 第2层是 11 。因此返回 [3, 14.5, 11] 。
提示:
-
节点值的范围在32位有符号整数范围内。
Solution
二叉树的层序遍历,很简单的BFS+queue。
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution:
def averageOfLevels(self, root: TreeNode) -> List[float]:
queue, res = [root], []
while queue:
curLevel, size = [], len(queue)
for i in range(size):
node = queue.pop(0)
if node.left: queue.append(node.left)
if node.right: queue.append(node.right)
curLevel.append(node.val)
res.append(sum(curLevel) / len(curLevel))
return res
来都来了,点个
在看
,好吗