题解 | #重建二叉树#

重建二叉树

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

/* function TreeNode(x) {
    this.val = x;
    this.left = null;
    this.right = null;
} */
function reConstructBinaryTree(pre, vin)
{
    // write code here
    n = pre.length;
    m = vin.length;
    if(n === 0 && m === 0)
        return null;
    let root = new TreeNode(pre[0]);
    for(let i=0;i<vin.length;i++){
        if(vin[i] === pre[0]){
            let leftPre = pre.slice(1,i+1);
            let leftVin = vin.slice(0,i);
            root.left = reConstructBinaryTree(leftPre,leftVin);

            let rightPre = pre.slice(i+1);
            let rightVin = vin.slice(i+1);
            root.right = reConstructBinaryTree(rightPre,rightVin);

            break;
        }
    }
    return root;
}

module.exports = {
    reConstructBinaryTree : reConstructBinaryTree
};

#我的实习求职记录#
全部评论

相关推荐

苗条的伊泽瑞尔最喜欢...:同28届被压力了,电科✌就不能去卷算法吗?把Java留给我们双非卷
投递快手等公司10个岗位
点赞 评论 收藏
分享
11-19 18:44
已编辑
成都理工大学 Java
程序员花海:我面试过100+校招生,大厂后端面试不看ACM,竞赛经历含金量低于你有几份大厂实习 这个简历整体来看不错 可以海投
如何写一份好简历
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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