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

最大二叉树--p654--递归构造

时间:2018-05-05 19:44:26      阅读:170      评论:0      收藏:0      [点我收藏+]

标签:str   max   节点   maximum   ons   一个   generic   col   最大值   

与p106相似

package tree;

import sun.reflect.generics.tree.Tree;

/**
 * 给定一个不含重复元素的整数数组。一个以此数组构建的最大二叉树定义如下:

 二叉树的根是数组中的最大元素。
 左子树是通过数组中最大值左边部分构造出的最大二叉树。
 右子树是通过数组中最大值右边部分构造出的最大二叉树。

 通过给定的数组构建最大二叉树,并且输出这个树的根节点。

 Example 1:

 输入: [3,2,1,6,0,5]
 输入: 返回下面这棵树的根节点:

 6
 /    3     5
 \    /
 2  0
  1

 注意:

 给定的数组的大小在 [1, 1000] 之间。


 */
public class p654 {
    public TreeNode constructMaximumBinaryTree(int[] nums) {
            if(nums.length==0)return null;
            if(nums.length==1)return new TreeNode(nums[0]);
            TreeNode root=null;
            root=buildTree(nums);
            return root;
    }

    public TreeNode buildTree(int []nums){
        if(nums.length==0)return null;
        int i,max=0,maxIndex=-1;
        for(i=0;i<nums.length;i++){     //找到最大值
            if(max<nums[i]){
                max=nums[i];
                maxIndex=i;
            }
        }
        TreeNode node=new TreeNode(nums[maxIndex]);
        //左子树数组
        int leftTree[]=new int[maxIndex];
        System.arraycopy(nums,0,leftTree,0,leftTree.length);
        //右子树数组
        int rightTree[]=new int[nums.length-maxIndex-1];
        System.arraycopy(nums,maxIndex+1,rightTree,0,rightTree.length);
        node.left=buildTree(leftTree);
        node.right=buildTree(rightTree);
        return node;
    }
}

 

最大二叉树--p654--递归构造

标签:str   max   节点   maximum   ons   一个   generic   col   最大值   

原文地址:https://www.cnblogs.com/ming-szu/p/8995539.html

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