LeetCode Hot100 | Day6 | 从前序和中序数组构建二叉树

LeetCode Hot100 | Day6 | 从前序和中序数组构建二叉树

从前序和中序数组构建二叉树

105. 从前序与中序遍历序列构造二叉树 - 力扣(LeetCode)

c++ 复制代码
class Solution {
public:
    TreeNode *tra(vector<int> preorder, vector<int> inorder)
    {
        if(preorder.size()==0)
            return nullptr;
        int val=preorder[0];
        TreeNode* t=new TreeNode (val);
        int index=0;
        for(index=0;index<inorder.size();index++)
            if(val==inorder[index])
                break;
        t->left=tra(vector<int>(preorder.begin()+1,preorder.begin()+1+index),vector<int>(inorder.begin(),inorder.begin()+index));
        t->right=tra(vector<int>(preorder.begin()+1+index,preorder.end()),vector<int>(inorder.begin()+index+1,inorder.end()));
        return t;
    }
    TreeNode* buildTree(vector<int>& preorder, vector<int>& inorder) {
        return tra(preorder,inorder);
    }
};

读者可以参考这篇博客来学习本题解法,思路都一样

代码随想录 | Day25 | 二叉树:从中序与后序遍历构造二叉树&&最大二叉树-CSDN博客

注意点:切割子树的前序和中序区间的时候要注意使用的区间要统一

前闭后开就全都前闭后开

前开后闭就全都前开后闭

相关推荐
oi..8 分钟前
Flag入门—Flag在返回包中
网络·笔记·测试工具·安全·网络安全
职豚求职小程序20 分钟前
[特殊字符]京东笔试在线系统练习笔试题库更新版本
笔记
励志的小陈25 分钟前
双指针算法--移除元素、删除有序数组中的重复项、合并两个有序数组
算法
NULL指向我25 分钟前
信号处理学习笔记2:软件RC二阶高通\低通滤波
笔记·学习·信号处理
左左右右左右摇晃26 分钟前
ConcurrentHashMap ——put + get
java·开发语言·笔记
Summer_Uncle36 分钟前
【QT学习】Qt界面布局的生命周期和加载时机
c++·qt
啥咕啦呛38 分钟前
java打卡学习4:HashMap底层结构、扩容机制
java·学习·哈希算法
朱一头zcy44 分钟前
设计模式入门:最简单的模板方法模式
笔记·设计模式·模板方法模式
小CC吃豆子1 小时前
C++ 继承
开发语言·c++
hoiii1871 小时前
Mean Shift目标跟踪算法MATLAB实现
算法·matlab·目标跟踪