LeetCode Java刷题笔记—199. 二叉树的右视图

Posted 刘Java

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode Java刷题笔记—199. 二叉树的右视图相关的知识,希望对你有一定的参考价值。

199. 二叉树的右视图

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

中等难度。这道题所谓的右视图,实际上就是求二叉树的每一层的最右侧节点。那么最简单的是我们使用从右到左的BFS层序遍历即可,获取每一层的第一个节点并加入结果集合。

public List<Integer> rightSideView(TreeNode root) 
    LinkedList<Integer> res = new LinkedList<>();
    if (root == null) 
        return res;
    
    LinkedList<TreeNode> queue = new LinkedList<>();
    queue.addLast(root);
    while (!queue.isEmpty()) 
        int size = queue.size();
        for (int i = 0; i < size; i++) 
            root = queue.removeFirst();
            //第一个元素
            if (i == 0) 
                res.addLast(root.val);
            
            //从右到左中序遍历
            if (root.right != null) 
                queue.addLast(root.right);
            
            if (root.left != null) 
                queue.addLast(root.left);
            
        
    
    return res;

另一种方式是使用DFS深度优先遍历,同样对于每一层的第一个节点加入结果集即可。

List<Integer> res = new ArrayList<>();

public List<Integer> rightSideView(TreeNode root) 
    dfs(root, 0);
    return res;


void dfs(TreeNode root, int depth) 
    if (root == null) 
        return;
    
    //如果当前层深度等于结果集数量,则说明当前节点是当前层的最右节点
    if (depth == res.size()) 
        res.add(root.val);
    
    depth++;
    dfs(root.right, depth);
    dfs(root.left, depth);

以上是关于LeetCode Java刷题笔记—199. 二叉树的右视图的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode刷题笔记-数据结构-day16

Leetcode刷题Python199. 二叉树的右视图

LeetCode Java刷题笔记—226. 翻转二叉树

LeetCode Java刷题笔记—111. 二叉树的最小深度

LeetCode Java刷题笔记—101. 对称二叉树

LeetCode Java刷题笔记—101. 对称二叉树