农场里有一群牛,牛群的成员分布在山坡上,形成了一个二叉树结构。每头牛都有一个编号,表示它在牛群中的身份。现在农场主想要重建牛群的二叉树结构。给定两个整数数组 preOrder 和 inOrder,其中 preOrder 是牛群二叉树的先序遍历,inOrder 是同一棵树的中序遍历,请构造二叉树并返回其根节点。

区块链毕设网qklbishe.com为您提供问题的解答

农场里有一群牛,牛群的成员分布在山坡上,形成了一个二叉树结构。每头牛都有一个编号,表示它在牛群中的身份。现在农场主想要重建牛群的二叉树结构。给定两个整数数组 preOrder 和 inOrder,其中 preOrder 是牛群二叉树的先序遍历,inOrder 是同一棵树的中序遍历,请构造二叉树并返回其根节点。

import java.util.*;  /*  * public class TreeNode {  *   int val = 0;  *   TreeNode left = null;  *   TreeNode right = null;  *   public TreeNode(int val) {  *     this.val = val;  *   }  * }  */  public class Solution {     /**      * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可      *      *       * @param preOrder int整型一维数组       * @param inOrder int整型一维数组       * @return TreeNode类      */     public TreeNode buildTreeII (int[] preOrder, int[] inOrder) {         if(preOrder.length==0) return null;         TreeNode root=new TreeNode(preOrder[0]);         int i=find(inOrder,preOrder[0]),n=preOrder.length;         root.left=buildTreeII(slice(preOrder,1,i+1),slice(inOrder,0,i));         root.right=buildTreeII(slice(preOrder,i+1,n),slice(inOrder,i+1,n));         return root;     }     public int find(int[] arr,int x){         for(int i=0;i<arr.length;i++){             if(arr[i]==x) return i;         }         return -1;     }     public int[] slice(int[] arr,int i,int j){         return Arrays.copyOfRange(arr,i,j);     } }

24:40

以上就是关于问题农场里有一群牛,牛群的成员分布在山坡上,形成了一个二叉树结构。每头牛都有一个编号,表示它在牛群中的身份。现在农场主想要重建牛群的二叉树结构。给定两个整数数组 preOrder 和 inOrder,其中 preOrder 是牛群二叉树的先序遍历,inOrder 是同一棵树的中序遍历,请构造二叉树并返回其根节点。的答案

欢迎关注区块链毕设网-
专业区块链毕业设计成品源码,定制。

区块链NFT链游项目方科学家脚本开发培训

承接区块链项目定制开发

微信:btc9767

QQ :1330797917

TELEGRAM: BTCOK9

承接区块链项目定制开发


qklbishe.com区块链毕设代做网专注|以太坊fabric-计算机|java|毕业设计|代做平台-javagopython毕设 » 农场里有一群牛,牛群的成员分布在山坡上,形成了一个二叉树结构。每头牛都有一个编号,表示它在牛群中的身份。现在农场主想要重建牛群的二叉树结构。给定两个整数数组 preOrder 和 inOrder,其中 preOrder 是牛群二叉树的先序遍历,inOrder 是同一棵树的中序遍历,请构造二叉树并返回其根节点。