题解 | #重建二叉树#

重建二叉树

https://www.nowcoder.com/practice/8a19cbe657394eeaac2f6ea9b0f6fcf6

/**
 * struct TreeNode {
 *  int val;
 *  struct TreeNode *left;
 *  struct TreeNode *right;
 *  TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 * };
 */
#include <vector>
class Solution {
  public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param preOrder int整型vector
     * @param vinOrder int整型vector
     * @return TreeNode类
     */
    TreeNode* reConstructBinaryTreeFun(vector<int>& preOrder, vector<int>& vinOrder,
                                       int preBegin, int preEnd, int vinBegin, int vinEnd) {
        if (preOrder.empty() || vinOrder.empty())
            return nullptr;
        auto root = new TreeNode(preOrder[preBegin]);
        if (preBegin == preEnd)
            return root;
        int index = vinBegin;
        while (index != vinEnd + 1 && vinOrder[index] != preOrder[preBegin]) {
            index++;
        }
        if (index == vinBegin) {
            root->right = reConstructBinaryTreeFun(preOrder, vinOrder, preBegin + 1, preEnd,
                                                   vinBegin + 1, vinEnd);
            return root;
        }
        if (index == vinEnd) {
            root->left = reConstructBinaryTreeFun(preOrder, vinOrder, preBegin + 1, preEnd,
                                                  vinBegin, vinEnd - 1);
            return root;
        }
        root->left = reConstructBinaryTreeFun(preOrder, vinOrder, preBegin + 1,
                                              preBegin + index - vinBegin, vinBegin, index - 1);
        root->right = reConstructBinaryTreeFun(preOrder, vinOrder,
                                               preBegin + index - vinBegin + 1, preEnd, index + 1, vinEnd);
        return root;
    }
    TreeNode* reConstructBinaryTree(vector<int>& preOrder, vector<int>& vinOrder) {
        // write code here
        if (preOrder.empty() || vinOrder.empty())
            return nullptr;
        return reConstructBinaryTreeFun(preOrder, vinOrder, 0, preOrder.size() - 1, 0,
                                        vinOrder.size() - 1);
    }
};

全部评论

相关推荐

缓解焦虑的最好方法是回家。鼠鼠昨天上午考完了本科阶段的最后一场考试,大概率考得稀烂,但是没多想,考完立马收拾行李,坐上了提前约好的顺风车飞奔回家。虽然家和学校很近,只有一百多公里的路程,但距离上次回家也已经有三四个月了。每次想回家,期间总有考试、毕业设计、面试、实习等等各种各样的原因,没办法回去,待在学校和公司的每一天也都充斥着无形的压力和焦虑。现在终于完成了答辩,考完了试,公司那边也请了假,是时候回去一趟了。没有提前通知爸妈,想给他们一个惊喜。下午提前到了家,他俩还在上班,只好让外公外婆来给我开门。因为我的回家,晚上外婆在厨房格外忙碌,做了满满一大桌子菜,填饱了我天天吃外卖的肚子。晚上也没空...
梦想是成为七海千秋:取决于家庭吧?其实回家更焦虑了,每天起床父母都问实习找好了没简历投递了没今天有没有面试,但是又没有什么结果,玩两下手机父母就会说你看你啥也没找到为什么天天就知道刷手机,怎么不去学习…我现在就希望我能永远在外面实习,报喜不报忧,等拿到一个好offer再回家
点赞 评论 收藏
分享
Ncsbbss:又想干活又想要工资,怎么什么好事都让你占了
点赞 评论 收藏
分享
北漂的牛马人:211佬,包进的,可能是系统问题
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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