199. 二叉树的右视图

Posted lzh1043060917

tags:

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

技术图片

 

 很简单,来个层次遍历,当遍历队列,遍历到刚开始遍历时,队列里最后一个数时(也就是遍历len-1次),得到的就是右视图的其中一个节点

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {//利用层次遍历,看笔记,自己写的
    public List<Integer> rightSideView(TreeNode root) {
       
        List<Integer> res=new ArrayList<Integer>();
         if(root==null) return res;
        Queue<TreeNode> queue=new LinkedList<TreeNode>();
        queue.add(root);
        while(!queue.isEmpty())//层次遍历
        {
            int len=queue.size();
            for(int i=0;i<len;i++)
            {
                TreeNode n=queue.remove();
                if(n.left!=null) queue.add(n.left);
                if(n.right!=null) queue.add(n.right);
                if(i==len-1) res.add(n.val);
            }
        }
    return res;
    }
}

  

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

leetcode 199 二叉树的右视图

广度优先搜索199.二叉树的右视图

199. 二叉树的右视图

199. 二叉树的右视图

199. 二叉树的右视图

199. 二叉树的右视图