199. Binary Tree Right Side View

Binary Tree Right Side View

Given a binary tree, imagine yourself standing on the right side of it, return the values of the nodes you can see ordered from top to bottom.

For example: Given the following binary tree,

1 <--- / \ 2 3 <--- \ \ 5 4 <---

You should return [1, 3, 4].

Credits:Special thanks to @amrsaqr for adding this problem and creating all test cases.

Solution

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
public class Solution {
         public List<Integer> rightSideView(TreeNode root) {
        List<Integer> result = new ArrayList<>();
        if (root == null) return result;

        List<TreeNode> nodes = new ArrayList<>();
        nodes.add(root);

        while (!nodes.isEmpty()) {
            result.add(nodes.get(nodes.size()-1).val);

            List<TreeNode> nextLevel = new ArrayList<>();
            for(TreeNode n: nodes) {
                if (n.left != null) {
                    nextLevel.add(n.left);
                }

                if (n.right != null) {
                    nextLevel.add(n.right);
                }
            }

            nodes = nextLevel;
        }

        return result;
    }

}

Last updated