题解 | #输出二叉树的右视图#

输出二叉树的右视图

http://www.nowcoder.com/practice/c9480213597e45f4807880c763ddd5f0

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 * 求二叉树的右视图
 * @param xianxu int整型一维数组 先序遍历
 * @param zhongxu int整型一维数组 中序遍历
 * @return int整型一维数组
 */

/*
 * function TreeNode(x) {
 *   this.val = x;
 *   this.left = null;
 *   this.right = null;
 * }
 */
function solve( xianxu ,  zhongxu ) {
    // write code here
     
    //1.建树
    function buildTree(preOrder,inOrder){
         if (!preOrder.length || !inOrder.length) return null;
        
        const root=new TreeNode(preOrder.shift());
        
        const rootIndex=inOrder.findIndex(node=>node===root.val);
        
        root.left= buildTree(preOrder,inOrder.slice(0,rootIndex));
        
        root.right=buildTree(preOrder,inOrder.slice(rootIndex+1));
        
        return root;
   }
    
    const treeNode = buildTree(xianxu,zhongxu);
    
    
//     return treeNode;
    

    
//     // 2 输出右视图
    
    if( treeNode == null) return [];
    
    const res=[];
    const queue=[];
    
    queue.push(treeNode);
    
    while(queue.length){
        let len=queue.length;
        
        while(len--){
            const node=queue.shift();
            if(!len){
                res.push(node.val);
            }
            
            if(node.left){
                queue.push(node.left);
            }
            
            if(node.right){
                queue.push(node.right);
            }
        }
    }
    
    return res;
   
    
}
module.exports = {
    solve : solve
};
全部评论

相关推荐

11-29 11:21
门头沟学院 Java
总包48.5w,意想不到的价格
想开了的垂耳兔很喜欢拱白菜:转人工
点赞 评论 收藏
分享
11-09 11:01
济南大学 Java
Java抽象带篮子:外卖项目真得美化一下,可以看看我的详细的外卖话术帖子
点赞 评论 收藏
分享
评论
2
收藏
分享
牛客网
牛客企业服务