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

输出二叉树的右视图

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

import java.util.*;


class Node {
    int val ;
    Node left ;
    Node right ;
    Node() {}
    Node(int val) {this.val = val ;}
}
public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     * 求二叉树的右视图
     * @param xianxu int整型一维数组 先序遍历
     * @param zhongxu int整型一维数组 中序遍历
     * @return int整型一维数组
     */
    public int[] solve (int[] xianxu, int[] zhongxu) {
        //创建二叉树
        Node head = createTree(xianxu , zhongxu , 0 , 0 , xianxu.length) ;
        //求右视图(层序遍历)
        ArrayList<Integer> rightViewList = new ArrayList<>() ;
        Queue<Node> que = new LinkedList<>() ;
        que.offer(head) ;
        while(!que.isEmpty()) {
            //每一层的节点数
            int cur_row_len = que.size() ;
            for(int i = 0 ; i < cur_row_len ; i ++) {
                Node tmp = que.poll() ;
                //将每层最后一个节点加入右视图中
                if(i == cur_row_len - 1) rightViewList.add(tmp.val) ;
                if(tmp.left != null) que.offer(tmp.left) ;
                if(tmp.right != null) que.offer(tmp.right) ;
            }
        }
        int [] res = new int[rightViewList.size()] ;
        for(int i = 0 ; i < res.length ; i ++) {
            res[i] = rightViewList.get(i) ;
        }
        return res ;
    }
    //创建二叉树
    public Node createTree(int[] pre , int[] in , int preIdx , int inIdx , int len) {
        if(len == 0) return null ;
        Node root = new Node(pre[preIdx]) ;
        //寻找root在中序遍历序列中的位置
        int i = inIdx ;
        for(; i < inIdx + len ; i ++) {
            if(in[i] == root.val) break ;
        }
        int l_len = i - inIdx ;
        int r_len = len - l_len - 1 ;
        root.left = createTree(pre , in , preIdx + 1 , inIdx , l_len) ;
        root.right = createTree(pre , in , preIdx + l_len + 1 , i + 1 , r_len) ;
        return root ;
    }
}

一个菜鸟的算法刷题记录 文章被收录于专栏

分享一个菜鸟的成长记录

全部评论

相关推荐

2025-12-02 02:15
门头沟学院
最近菊厂陆续开了,极力劝退那些拿13级的985硕士,就13级那么点儿薪资,一线城市每个月到手1.8/7/6w,租房2k还是破烂,吃饭2k还是预制菜,买个1k衣服都是聚酯纤维破塑料,稍微出去浪一浪,能留1w就是万岁,要是再有个啥都想买的对象,一线工作一年难存10w。隔壁工地混泥土,钳工,焊工一天800+,还包吃包住。读书18年到985硕士出来就为了进厂螺丝工?还不如从8岁童工开始干活,别人读书完了你工龄18+,混不上领导也是个小头头了。当然专科进来正式工,od都行,一般本科进来13级也OK,毕竟22岁年纪摆在那个地方还不需要太花钱。读硕博的基本26岁,工作两年就要结婚的,兜里没几个崽,连彩礼都要信用贷。菊厂离职的不少,毕竟正常没人受得了9116(梗:再来一次911刷6)。为啥这时候劝?因为刚下班,因为国考刚完,省考下周,就是可惜选调只有当年应届能报。现在回想能拍断大腿。应届生真实好身份,错过这一次,选调,考公,考编,当老师,进医院,研究所,高校,央国企,基本都无缘了,就连报名资格都被剥夺了,可谓是被党和国家遗弃的废材,统称“社会上的”,扔到社会去流浪,被用坏了就扔医院,长期超负载使用,零件修不好基本可以扔火里回炉重造了。体制内奉行找体制内的,都是党和国家选的人才,智力不差,样貌不丑,身材端正,收入稳定,安居房政策福利待遇也OK。因公出行都是报销,周末顺带“游山玩水“,这种体制内单身资源但凡想找对象,去社会上随便吆喝一声都排队。观察一下,基本没什么公务员在相亲,因为早就被邻里邻居抢光了。
哈哈哈,你是老六:就这不去的人大把人干呢,现在不缺人干活,你不干大把干呢,还有那个说农民工赚钱的,那个800+我估计肯定也就那一段时间,哪有这么赚钱,还是一句话,要想存下钱必须花销极低,能省的就不花钱,工资要高点
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务