• 从中序与后序遍历序列构造二叉树


    从中序与后序遍历序列构造二叉树

    来自学习总结

    1.问题描述:

    根据一棵树的中序遍历后序遍历构造二叉树(假设树中没有重复的元素)

    中序遍历 inorder = [9,3,15,20,7] 后序遍历 postorder = [9,15,7,20,3] 返回如下的二叉树:

    在这里插入图片描述

    2.思路

    以后序数组的最后一个元素为切割点,先切中序数组,根据中序数组,反过来后序数组,一层一层切下去,每次后续数组最后一个元素就是节点元素

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Kppt0Y0Q-1659594016685)(../../../../002%E6%96%87%E6%A1%A3/Typroa/images/image-20220804113143791.png)]

    一层一层切割的步骤:(递归)

    1. 如果数组大小为0,说明是空节点
    2. 若不为空,name去后序数组最后一个元素作为节点元素
    3. 找到后序数组最后一个元素在中序数组的位置,作为切割点
    4. 切割中序数组,切成中序左数组和中序右数组
    5. 切割后续数组,切成后续数组和后序数组
    6. 递归处理左区间和右区间

    4.代码实现

    public  TreeNode* traversal(vector<int>&  inorder,vector<int>& postorder){
        //1.
        if(postorder.size()==0)  return null;
        //2.后续遍历的最后一个元素,就是当前的节点
        int rootVal=postorder[postorder.size()-1];
        TreeNode* root=new TreeNode(rootVal);
        //叶子结点
        if(postorder.size()==1) return root;
        //3.切割点
        int delimiterIndex;
        for(delimiterIndex=0;delimiterIndex<inorder.size();delimiterIndex++){
            if(inorder[delimiterIndex]==rootVal) break;
        }
        //4切割中序数组
        //左闭右开区间[0,delimiterIndex)
        vector<int> leftInorder(inorder.begin(),inorder.begin()+delimiterIndex);
        //[delimiterIndex+1,end)
        vector<int> rightInorder(inorder.begin()+delimiterIndex+1,index.end());
        //舍弃末尾元素
        postorder.resize(postorder.size()-1);
        //5切割后序数组
        //左闭右开,注意这里使用了左中序数组大小作为切割点[0,leftorder.size)
        vector<int> leftPostOrder(postorder.begin(),postorder.begin()+leftInorder.size());
        //[leftInorder.size(),end)
        vector<int>  rightPostorder(postorder.begin()+leftInorder.size(),postorder.end());
        
        //6.
        root->left=traversal();
        root->right=traversal();
        return root;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
  • 相关阅读:
    力扣370周赛 -- 第三题(树形DP)
    C中的基本函数
    第146篇 笔记-智能合约介绍
    Ansys Speos | 新型计算方法:使用 GPU 提升计算速率
    【附源码】计算机毕业设计SSM网上销售系统
    docker配置独立桥接IP
    通配符ssl证书的作用有哪些?为什么通配符ssl证书如此受欢迎?
    Python实现番茄小说内容下载
    数据结构试题 20-21
    (附源码)springboot篮球场地预约系统 毕业设计 345655
  • 原文地址:https://blog.csdn.net/weixin_43475992/article/details/126158716