每日算法之重建二叉树(重建二叉树 leetcode)

  本篇文章为你整理了每日算法之重建二叉树(重建二叉树 leetcode)的详细内容,包含有重建二叉树 剑指offer 重建二叉树 leetcode 重建二叉树java 重建二叉树c语言 每日算法之重建二叉树,希望能帮助你了解 每日算法之重建二叉树。

  

给定节点数为 n 的二叉树的前序遍历和中序遍历结果,请重建出该二叉树并返回它的头结点。

 

  例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6}

  1.vin.length == pre.length

  2.pre 和 vin 均无重复元素

  3.vin出现的元素均出现在 pre里

  4.只需要返回根结点,系统会自动输出整颗树做答案对比

  

 

  具体做法:

  

step 1:先根据前序遍历第一个点建立根节点。

 

  step 2:然后遍历中序遍历找到根节点在数组中的位置。

  step 3:再按照子树的节点数将两个遍历的序列分割成子数组,将子数组送入函数建立子树。

  step 4:直到子树的序列长度为0,结束递归。

  

 

  

package mid.JZ7重建二叉树;

 

  import java.util.*;

  
//左子树

   root.left = reConstructBinaryTree(Arrays.copyOfRange(pre, 1, i + 1), Arrays.copyOfRange(vin, 0, i));

   root.right = reConstructBinaryTree(Arrays.copyOfRange(pre, i + 1, pre.length), Arrays.copyOfRange(vin, i + 1, vin.length));

   break;

   return root;

  

 

  以上就是每日算法之重建二叉树(重建二叉树 leetcode)的详细内容,想要了解更多 每日算法之重建二叉树的内容,请持续关注盛行IT软件开发工作室。

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

留言与评论(共有 条评论)
   
验证码: