前序,中序遍历序列重建二叉树

输出二叉树的右视图

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

/*
根据先序遍历和中序遍历重建二叉树步骤:
1.先序的第一个元素pre[pstart]就是根节点,在中序中找到这个根节点的下标k。下标从0开始
2.找到根节点下标后,那么左子树节点个数是:k-istart
3.根节点的左子树寻找范围从pstart+1就可以了,中序的范围是 istart ---- k-1
4.根节点的右子树范围从先序的 pstart + k-istart +1。pos代表在先序序列中右子树根节点的下标。
中序序列中,从k+1到iend即可
*/
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     * 求二叉树的右视图
     * @param xianxu int整型vector 先序遍历
     * @param zhongxu int整型vector 中序遍历
     * @return int整型vector
     */
    /*
    根据先序遍历和中序遍历重建二叉树步骤:
    1.先序的第一个元素pre[pstart]就是根节点,在中序中找到这个根节点的下标k。下标从0开始
    2.找到根节点下标后,那么左子树节点个数是:k-istart
    3.根节点的左子树寻找范围从pstart+1就可以了,中序的范围是 istart ---- k-1
    4.根节点的右子树范围从先序的 pstart + k-istart +1。pos代表在先序序列中右子树根节点的下标。
    中序序列中,从k+1到iend即可
    */
    TreeNode * fun(vector<int> &pre,int pstart,vector<int> &inorder,int istart,int iend)
    {
        if(istart>iend)
        {
            return NULL;
        }
        TreeNode *root=new TreeNode(pre[pstart]);
        int k=0;
        for(int i=istart;i<=iend;i++)
        {
            if(inorder[i]==root->val)
            {
                k=i;//在中序遍历中,下标k是 根节点,比如k=3,istart=0,3-0=3,代表左子树有3个元素
                break;//pstart  +  k-istart  +  1。 pstart代表根节点下标,k-istart代表左子树元素个数,+1表示右子树根节点下标
            }
        }
        root->left=fun(pre,pstart+1,inorder,istart,k-1);
        root->right=fun(pre,pstart+k-istart+1,inorder,k+1,iend);//pstart+k-istart+1在前序基础上 + 中序上的偏移绝对值
        return root;
    }
    vector<int> solve(vector<int>& xianxu, vector<int>& zhongxu) {
        // write code here
        int n = zhongxu.size();
        TreeNode* root = fun(xianxu, 0, zhongxu, 0, zhongxu.size()-1);
        vector<int> res;
        if(!root)
            return res;
        queue<TreeNode*> que;
        que.push(root);
        while(que.size())
        {
            int n=que.size();
            for(int i=0;i<n;i++)
            {
                TreeNode* node=que.front();
                que.pop();
                if(i==n-1)
                {
                    res.push_back(node->val);
                }
                if(node->left)
                {
                    que.push(node->left);
                }
                if(node->right)
                {
                    que.push(node->right);
                }
            }
        }
        return res;
    }
};
全部评论

相关推荐

#牛客AI配图神器#和波主熟的朋友们都知道,波主真的很挺贪玩的哈哈哈哈很少看八股,也不爱看。。可能你们现在拷打波主八股会支支吾吾...回想我的面试,似乎都是围绕着我会的地方问,大概是最近和宿佬还有学长学到的引导面试罢...注意,此文只适合对面试技巧提升,并不是说可以不学八股啊喂!!回忆本人的面试经验,面试官刚拿到你的简历,对你是一无所知的,那其实他会根据印象深的东西对你进行提问,所以我们在简历方面可以做一个引导。面试开头是很正常的自我介绍,很多人会觉得随便说一下就好,但其实我们可以在这里也做一个引导的,而且多说一点也可以给面试官时间看你的简历,所以这里也可以准备一下。然后就是具体提问了,对实习...
nokotan:佬tql,还很谦虚。个人决定佬说得很对,要有意把面试官提问引导到简历项目上,但前提是自己对项目一定要熟悉。项目的需求背景、难点痛点、已有方案的不足、解决方案的实现都得有认知,虽然我们实习大多数是打杂,但是不影响我们偷文档学业务。只要能把上面几个点做到自圆其说,那基本就有6、7成把握了
点赞 评论 收藏
分享
03-27 13:58
门头沟学院 Java
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务