• Leetcode654 最大二叉树


    给定一个不重复的整数数组 nums 。 最大二叉树 可以用下面的算法从 nums 递归地构建:

    创建一个根节点,其值为 nums 中的最大值。
    递归地在最大值 左边 的 子数组前缀上 构建左子树。
    递归地在最大值 右边 的 子数组后缀上 构建右子树。
    返回 nums 构建的 最大二叉树

    输入:nums = [3,2,1,6,0,5]
    输出:[6,3,5,null,2,0,null,null,1]
    解释:递归调用如下所示:
    - [3,2,1,6,0,5] 中的最大值是 6 ,左边部分是 [3,2,1] ,右边部分是 [0,5]- [3,2,1] 中的最大值是 3 ,左边部分是 [] ,右边部分是 [2,1]- 空数组,无子节点。
            - [2,1] 中的最大值是 2 ,左边部分是 [] ,右边部分是 [1]- 空数组,无子节点。
                - 只有一个元素,所以子节点是一个值为 1 的节点。
        - [0,5] 中的最大值是 5 ,左边部分是 [0] ,右边部分是 []- 只有一个元素,所以子节点是一个值为 0 的节点。
            - 空数组,无子节点
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    在这里插入图片描述
    分析:首先看到题呢,想到的就是用递归的方法解决问题
    解法:

    /**
     * Definition for a binary tree node.
     * public class TreeNode {
     *     int val;
     *     TreeNode left;
     *     TreeNode right;
     *     TreeNode() {}
     *     TreeNode(int val) { this.val = val; }
     *     TreeNode(int val, TreeNode left, TreeNode right) {
     *         this.val = val;
     *         this.left = left;
     *         this.right = right;
     *     }
     * }
     */
    class Solution {
        public TreeNode constructMaximumBinaryTree(int[] nums) {
            return construct(nums, 0, nums.length - 1);
        }
    	
    	//定义一个递归方法
        public TreeNode construct(int[] nums, int left, int right) {
            if (left > right) {  //如果左边大于右边,直接返回空值
                return null;
            }
            int best = left;   //定义最大值为左边的left
            for (int i = left + 1; i <= right; ++i) {
                if (nums[i] > nums[best]) {    //如果出现比left大的值
                    best = i;  //让这个值为best
                }
            }
            TreeNode node = new TreeNode(nums[best]);
            node.left = construct(nums, left, best - 1);
            node.right = construct(nums, best + 1, right);
            return node;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37

    来源:力扣(LeetCode
    链接:https://leetcode.cn/problems/maximum-binary-tree
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

  • 相关阅读:
    离散数学 --- 特殊图 --- 欧拉图,哈密顿图
    WebVR — 网络虚拟现实
    输入神经网络的数据类型要求,神经网络数据格式
    CDISC SDTM IG 3.3 版本相比于 3.2版本的变化 (下)
    Spring Ioc 容器启动流程
    Pytorch实现线性回归
    计算机网络(IP/TCP网络分层)
    Orange3数据可视化组件概览
    SpringCloud微服务(注册发现Nacos、服务调用SSM、网关gateway)项目环境搭建(项目概况,SSM细节总结)
    leaflet+vue2实现地图交互
  • 原文地址:https://blog.csdn.net/wjl0_7/article/details/126445092