给定一棵二叉树的根节点 root ,请找出该二叉树中每一层的最大值。

    示例1:
    image.png
    输入: root = [1,3,2,5,3,null,9]
    输出: [1,3,9]
    示例2:

    输入: root = [1,2,3]
    输出: [1,3]

    1. /**
    2. * Definition for a binary tree node.
    3. * function TreeNode(val, left, right) {
    4. * this.val = (val===undefined ? 0 : val)
    5. * this.left = (left===undefined ? null : left)
    6. * this.right = (right===undefined ? null : right)
    7. * }
    8. */
    9. /**
    10. * @param {TreeNode} root
    11. * @return {number[]}
    12. */
    13. var largestValues = function (root) {
    14. // 层级遍历,找每一层最大值
    15. let res = [];
    16. const traverse = (node, depth) => {
    17. if (!node) return;
    18. if (res[depth] !== undefined) {
    19. res[depth] = Math.max(res[depth], node.val);
    20. } else {
    21. res[depth] = node.val;
    22. }
    23. traverse(node.left, depth + 1);
    24. traverse(node.right, depth + 1);
    25. }
    26. traverse(root, 0);
    27. return res;
    28. };

    image.png