首页 > 其他 > 详细

construct-binary-tree-from-preorder-and-inorder-traversal

时间:2016-05-22 22:45:08      阅读:217      评论:0      收藏:0      [点我收藏+]

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

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

package com.cn.cya.constructbinarytreefrompreorderandinordertraversal;
class TreeNode {
     int val;
     TreeNode left;
     TreeNode right;
     TreeNode(int x) { val = x; }
 }
public class Solution {
    public TreeNode buildTree(int[] preorder, int[] inorder) {
        if(preorder==null||preorder.length==0||inorder==null||inorder.length==0||preorder.length!=inorder.length)
            return null;
    
        
        return build_Tree(preorder,0,preorder.length-1,inorder,0,inorder.length-1);
    }
    public TreeNode buildTree(int[] preorder,int prestar,int preend,int[] inorder,int instar,int inend){
        if(prestar>preend||instar>inend)return null;
        int root_val=preorder[prestar];
        TreeNode root=new TreeNode(root_val);
        int index=instar;//preorder中第一个元素在中序遍历中的位置
        for (;index < inend&&inorder[index]!=root_val; index++) {    
        }
        root.left=buildTree(preorder,prestar+1, prestar+index-instar, inorder,instar,index-1);
        root.right=buildTree(preorder,prestar+index-instar+1, preend, inorder,index+1,inend);
        return root;
    }
  
}

 

construct-binary-tree-from-preorder-and-inorder-traversal

原文:http://www.cnblogs.com/softwarewebdesign/p/5517830.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!