根据前中序列构造二叉树

力扣题目

图示分析

代码实现

C语言代码实现:

cpp 复制代码
//构造树
struct TreeNode* buildTree(int* p, int pSize, int* in, int inSize){
    return CreatTree(p,in,0,0,pSize-1);
}
struct TreeNode*CreatTree(int*p,int*in,int index,int left,int right)
{
    //在left到right的范围内构造树,p为前序数组,in为中序数组,index为待构建根在前序p中下标
    if(left>right)
    	return NULL;
    
    //创建根节点
    struct TreeNode*root=(struct TreeNode*)malloc(sizeof(struct TreeNode));
    root->val=p[index];
    root->left=NULL;
    root->right=NULL;
    
    //找到根节点在中序in中的位置pos,找pos的目的一是为了找到右孩子,而是为了划分构建返回
    int pos=left;
    while(left<right&&p[index]!=in[pos])
    {
        pos++;
    }
    
    root->left=CreatTree(p,in,index+1,left,pos-1);//连接左孩子,并构造左侧区域子树
    root->right=CreatTree(p,in,pos+1-left+index,pos+1,right);//连接右孩子,并构造右侧区域子树
    
    return root;
}
相关推荐
2401_841495643 分钟前
【LeetCode刷题】打家劫舍
数据结构·python·算法·leetcode·动态规划·数组·传统dp数组
冰西瓜60021 分钟前
STL——vector
数据结构·c++·算法
天呐草莓23 分钟前
集成学习 (ensemble learning)
人工智能·python·深度学习·算法·机器学习·数据挖掘·集成学习
努力学算法的蒟蒻23 分钟前
day45(12.26)——leetcode面试经典150
算法·leetcode·面试
闻缺陷则喜何志丹32 分钟前
【离线查询 前缀和 二分查找 栈】P12271 [蓝桥杯 2024 国 Python B] 括号与字母|普及+
c++·算法·前缀和·蓝桥杯·二分查找··离线查询
夏幻灵1 小时前
为什么要配置环境变量?
笔记·算法
铭哥的编程日记1 小时前
Manacher算法解决所有回文串问题 (覆盖所有题型)
算法
LYFlied1 小时前
【每日算法】LeetCode 300. 最长递增子序列
前端·数据结构·算法·leetcode·职场和发展
ohnoooo91 小时前
251225 算法2 期末练习
算法·动态规划·图论
车队老哥记录生活1 小时前
强化学习 RL 基础 3:随机近似方法 | 梯度下降
人工智能·算法·机器学习·强化学习