LeetCode刷题(JS版) - 637二叉树的层平均值

66 阅读1分钟

题目

给定一个非空二叉树的根节点 root , 以数组的形式返回每一层节点的平均值。与实际答案相差 10-5 以内的答案可以被接受。

示例 1:

输入:root = [3,9,20,null,null,15,7]
输出:[3.00000,14.50000,11.00000]
解释:第 0 层的平均值为 3,第 1 层的平均值为 14.5,第 2 层的平均值为 11 。
因此返回 [3, 14.5, 11]

示例 2:

输入:root = [3,9,20,15,7]
输出:[3.00000,14.50000,11.00000]

提示:

树中节点数量在 [1, 104] 范围内
-231 <= Node.val <= 231 - 1

思路: 队列层级遍历

  • 用队列辅助层级遍历,对每层值进行求和
/**
 * Definition for a binary tree node.
 * class TreeNode {
 *     val: number
 *     left: TreeNode | null
 *     right: TreeNode | null
 *     constructor(val?: number, left?: TreeNode | null, right?: TreeNode | null) {
 *         this.val = (val===undefined ? 0 : val)
 *         this.left = (left===undefined ? null : left)
 *         this.right = (right===undefined ? null : right)
 *     }
 * }
 */

function averageOfLevels(root: TreeNode | null): number[] {
    const result = [];
    const queue = [];
    let i = 0;

    if(!root) return result;

    queue.push(root);
    while(queue.length) {
        let length = queue.length;
        result[i++] = queue.reduce((sum, curr) => sum + curr.val, 0) / length;
        // 下一层
        while(length--) {
            const node = queue.shift();
            node.left && queue.push(node.left);
            node.right && queue.push(node.right)
        }
    }

    return result
};

image.png