105. Construct Binary Tree from Preorder and Inorder Traversal

原题

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

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

代码实现

the most important function in solving this issue is

private TreeNode bulidTree(int preStart, int inStart, int inEnd) ;

Plus, preStart index in preorder is the root index, which is also the separate point in inorder and it’s left is left subtree and right is right subtree.

public class Solution 
{
    private  int[] _preorder; //preorder array
    private  int[] _inorder; //inorder array
    public TreeNode BuildTree(int[] preorder, int[] inorder)
     {
        _preorder = preorder;
        _inorder = inorder;
        //if(_preorder.Length==0 || inorder.Length==0) return null;
        //if(prorder.Length!=inorder.Length) return null;
        return bulidTree(0,0,_inorder.Length-1);
    }
    //preStart: index of root of tree
    //inStart: of inorder tree, inStart ~ root index - 1 -> left tree
    //EndStart:of inorder tree, root index + 1 ~ inEnd -> right tree
    private TreeNode  bulidTree(int preStart, int inStart, int inEnd) 
    {
        if (preStart > _preorder.Length - 1 || inStart > inEnd)
         {
            return null;
        }
        TreeNode root = new TreeNode(_preorder[preStart]); 
        // find the index of current root in inorder. 
        int inIndex = curRootIndex(inStart, inEnd, root); 
        root.left = bulidTree(preStart + 1, inStart, inIndex - 1);
        //right subtree begins position in preorder
        preStart += inIndex - inStart + 1; 
        root.right = bulidTree(preStart, inIndex + 1, inEnd);
        return root;
    }

      private int curRootIndex(int inStart, int inEnd, TreeNode root)
      {
           for (int i = inStart; i <= inEnd; i++) 
           {
               if (_inorder[i] == root.val) 
                {
                   return i;
                }
            }
          return -1;
        }

  }

leetcode-solution库

leetcode算法题目解决方案每天更新在github库中,欢迎感兴趣的朋友加入进来,也欢迎star,或pull request。https://github.com/jackzhenguo/leetcode-csharp

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值