先递归右子树, 再递归左子树, 记录层高, 第一次到达该层的时候, 记录答案 @param root @return
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
| class TreeNode { int val; TreeNode left; TreeNode right; TreeNode() {} TreeNode(int val) { this.val = val; } TreeNode(int val, TreeNode left, TreeNode right) { this.val = val; this.left = left; this.right = right; } }
class Solution {
public List<Integer> rightSideView(TreeNode root) { List<Integer> ans = new ArrayList<>(); dfs(ans, root, 0); return ans; }
private void dfs(List<Integer> ans, TreeNode root, int level) { if (root == null) return ; if (level == ans.size()) { ans.add(root.val); } dfs(ans, root.right, level+1); dfs(ans, root.left, level+1); } }
|