题解 | #重建二叉树#

重建二叉树

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

int ptr=0;
struct TreeNode* build(struct TreeNode* root,int* preOrder,int* vinOrder,int front,int rear)
{
    if(front>rear) return NULL;
    root=malloc(sizeof(struct TreeNode));
    root->val=preOrder[ptr++];
    int i=front;
    for(;i<rear;i++) if(vinOrder[i]==root->val) break;
    root->left=build(root->left,preOrder,vinOrder,front,i-1);
    root->right=build(root->right,preOrder,vinOrder,i+1,rear);
    return root;
}

struct TreeNode* reConstructBinaryTree(int* preOrder, int preOrderLen, int* vinOrder, int vinOrderLen ) {
    int front=0,rear=vinOrderLen-1;
    struct TreeNode* root;
    return build(root,preOrder,vinOrder,front,rear);
}

全部评论

相关推荐

Aaso:挺好的,早挂早超生
点赞 评论 收藏
分享
佛系的本杰明反对画饼:个人看法,实习经历那段是败笔,可以删掉,它和你目标岗位没什么关系,没有用到什么专业技能,甚至会降低你项目经历内容的可信度。个人技能那里可以再多写一点,去boss直聘上看别人写的岗位要求,可以把你会的整合一下,比如熟悉常规的开关电源拓扑结构(BUCK、正激、反激、LLC等),熟悉常用的通信总线协议和通信接口,如UART,IIC,SPI等。简历首先是HR看的,HR大多不懂技术,会从简历里去找关键字,你没有那些关键字他可能就把你筛掉了,所以个人技能尽量针对着岗位描述写一下。还有电赛获佳绩,获奖了就写什么奖,没获奖就把获佳绩删了吧,要不会让人感觉夸大。
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务