zoukankan      html  css  js  c++  java
  • Construct Binary Tree from Inorder and Postorder Traversal

    Given inorder and postorder traversal of a tree, construct the binary tree.

    Note:
    You may assume that duplicates do not exist in the tree.

    思路:从中序遍历和后序遍历的数组中找到唯一的二叉树。首先找到根结点,后序遍历最末位是根结点,然后找出中序遍历根结点的位置,记录index,且计算左子树的长度。递归方法,在左子树和右子树的遍历数组中再找出左子树和右子树的根结点,以此类推。

    /**
     * Definition for binary tree
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     * };
     */
    class Solution {
    public:
        void buildBST(TreeNode *&root,vector<int> &inorder,int inBegin,int inEnd,vector<int> &postorder,int postBegin,int postEnd)
        {
            if(inBegin>inEnd || postBegin>postEnd)
                return;
            int pRoot=postorder[postEnd];
            root=new TreeNode(pRoot);
            int index=0;
            for(int i=0;i<=inEnd;i++)
            {
                if(pRoot==inorder[i])
                {
                    index=i;
                    break;
                }
            }
            int in_len=index-inBegin;
            buildBST(root->left,inorder,inBegin,index-1,postorder,postBegin,postBegin+in_len-1);
            buildBST(root->right,inorder,index+1,inEnd,postorder,postBegin+in_len,postEnd-1);
        }
        TreeNode *buildTree(vector<int> &inorder, vector<int> &postorder) {
            TreeNode *root;
            if(inorder.empty() || postorder.empty())
                return NULL;
            int inEnd=inorder.size()-1;
            int postEnd=postorder.size()-1;
            buildBST(root,inorder,0,inEnd,postorder,0,postEnd);
            return root;
        }
    };
  • 相关阅读:
    PKU 学生的反馈 20091
    PKU 学生的反馈 2009 –2
    中国队有进步
    刚发现博客园又遇到了问题
    今日计划
    Delphi中使用多线程
    在老ASP中使用对象的对象生存期问题
    ASP与Javascript
    ASP & VBScript的错误处理
    对前一段时间学习网络和多线程编程的总结
  • 原文地址:https://www.cnblogs.com/awy-blog/p/3691943.html
Copyright © 2011-2022 走看看