给定一个二叉树的 根节点 root,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。

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

    输入: [1,null,3]
    输出: [1,3]
    示例 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 rightSideView = function (root) {
    14. let res = [], depth = 0;
    15. const traverse = (root) => {
    16. if (root == null) {
    17. return;
    18. }
    19. depth++;
    20. if (res.length < depth) {
    21. // 这一层还没有记录值
    22. // 说明 root 就是右侧视图的第一个节点
    23. res.push(root.val);
    24. }
    25. // 注意,这里反过来,先遍历右子树再遍历左子树
    26. // 这样首先遍历的一定是右侧节点
    27. traverse(root.right);
    28. traverse(root.left);
    29. depth--;
    30. }
    31. traverse(root)
    32. return res
    33. };

    image.png