力扣_数组29—根据前序与中序遍历序列构建二叉树、根据中序与后序遍历序列构建二叉树

题目

给定两个整数数组 p r e o r d e r preorder preorder 和 i n o r d e r inorder inorder ,其中 p r e o r d e r preorder preorder 是二叉树的先序遍历, i n o r d e r inorder inorder 是同一棵树的中序遍历,请构造二叉树并返回其根节点。

复习

  • 前序遍历(先根遍历):遍历顺序为,根节点---左节点(左子树)---右节点(右子树)
  • 中序遍历(中根遍历):遍历顺序为,左节点(左子树)---根节点---右节点(右子树)
  • 后序遍历(后根遍历):遍历顺序为,左节点(左子树)---右节点(右子树)---根节点

思路---递归

  • 对于任意一颗树而言,前序遍历的形式总是

    根节点, \[左子树的前序遍历结果\], \[右子树的前序遍历结果\]

    • 也就是说对于前序遍历序列,第一个必是根节点;第二个区间必是左子树的前序遍历序列;第三个区间必是右子树的前序遍历序列;
    • 问题是如何确定两个区间的起止点(靠中序遍历序列)
  • 即根节点总是前序遍历中的第一个节点。而中序遍历的形式总是

    \[左子树的中序遍历结果\], 根节点, \[右子树的中序遍历结果\]

    • 根据前序遍历序列找到根节点的位置,根节点前面的部分为左子树的中序遍历序列;后面的部分为右子树的中序遍历序列
    • 根据两个中序遍历序列的长度确定前序遍历序列中两个区间的起始点
  • 对于每个子树的前序遍历与中序遍历序列进行同样的操作

代码

c 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    TreeNode* subTree(vector<int>& preorder, vector<int>& inorder, int pre_l, int pre_r, int in_l, int in_r){
        if(pre_l == pre_r){
            return  new TreeNode(preorder[pre_l]);
        }
        int root_val = preorder[pre_l];
        TreeNode* root = new TreeNode(root_val);
        int tree_l_len = 0;
        for(int i = in_l; i <= in_r; i++){
            if(inorder[i] != root_val){
                tree_l_len++;
            }
            else{
                break;
            }
        }
        int tree_r_len = pre_r-pre_l-tree_l_len;
        if(tree_l_len>0){
            root->left = subTree(preorder, inorder, pre_l+1, pre_l+tree_l_len, in_l, in_l+tree_l_len-1);
        }
        if(tree_r_len>0){
            root->right = subTree(preorder, inorder, pre_l+tree_l_len+1, pre_r, in_r-tree_r_len+1, in_r);
        }
        return root;
    }
    TreeNode* buildTree(vector<int>& preorder, vector<int>& inorder) {
        TreeNode* ret = subTree(preorder, inorder, 0, preorder.size()-1, 0, preorder.size()-1);
        return ret;
    }

};
相关推荐
Dev7z12 小时前
基于Matlab遗传算法与蚁群算法的风光储并网微电网容量优化研究
算法·matlab·蚁群算法·多能源微电网
一直在努力的小宁12 小时前
《代码随想录-精华内容提取》07 二叉树
数据结构·算法·链表·面试
多彩电脑12 小时前
死循环逻辑检测
数据结构·python·算法·动态规划
cs麦子12 小时前
C语言--详解--冒泡排序(Bubble Sort)
c语言·算法·排序算法
2501_9411119312 小时前
基于C++的区块链实现
开发语言·c++·算法
hetao173383712 小时前
2025-11-16~17 hetao1733837的刷题记录
c++·算法
_OP_CHEN13 小时前
算法基础篇:(九)贪心算法拓展之推公式:从排序规则到最优解的推导艺术
c++·算法·贪心算法·推公式·算法竞赛·acm/icpc
小艳加油13 小时前
生态学研究突破:利用R语言多元算法实现物种气候生态位动态分析与分布预测,涵盖数据清洗、模型评价到论文写作全流程
开发语言·算法·r语言
t1987512814 小时前
基于盲源分离与贝叶斯非局部均值(BM3D)的图像降噪算法实现
算法·计算机视觉·均值算法
2501_9411118414 小时前
分布式日志系统实现
开发语言·c++·算法