码迷,mamicode.com
首页 > 其他好文 > 详细

Construct Binary Tree from Inorder and Postorder Traversal

时间:2015-04-18 06:26:50      阅读:175      评论:0      收藏:0      [点我收藏+]

标签:

跟另一道题一样,不多说了

public class Solution {
    public TreeNode buildTree(int[] inorder, int[] postorder) {
        // post就是pre的近似倒过来
        if(inorder==null|| postorder==null||inorder.length==0||postorder.length==0) return null;
        return buildTree(postorder, 0, postorder.length-1, inorder, 0, inorder.length-1);
    }
    public TreeNode buildTree(int[] p, int p1, int p2, int[] in, int in1, int in2 ){
        if(p2<p1||in2<in1) return null;
        int len=0;
        while(in[in1+len]!=p[p2]){
            len++;
        }
        TreeNode root = new TreeNode(p[p2]);
        root.left = buildTree(p,p1,p1+len-1,in,in1, in1+len-1);
        root.right = buildTree(p,p1+len,p2-1,in, in1+len+1,in2);
        return root;
    }
}

 

Construct Binary Tree from Inorder and Postorder Traversal

标签:

原文地址:http://www.cnblogs.com/jiajiaxingxing/p/4436535.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!