leetcode654-最大二叉树

leetcode 654

思路

首先找到数组中最大的值,作为根节点,然后左子树就递归最大值的左边数组,右子树就递归最大值右侧的数组,分别也找到最大值作为节点,当数组不存在的时候说明递归结束,没有节点可递归,如果数组中只存在一个值的时候,也没必要再去专门查询一次最大值,因为只有当前一个值,那可以直接构造当前节点

实现

js 复制代码
class TreeNode {
    constructor(val) {
        this.val = val;
        this.left = null;
        this.right = null;
    }
}
var constructMaximumBinaryTree = function (nums) {
    if (!nums.length) return null;
    const deep = (nums) => {
        if (!nums.length) return null;
        if (nums.length === 1) {
            return new TreeNode(nums[0])
        }
        // 获取最大值以及索引
        const [max, index] = findMaxNumber(nums)
        // 构造根节点
        const root = new TreeNode(max);
        // 分割
        const left = nums.slice(0, index)
        const right = nums.slice(index + 1)
        root.left = deep(left)
        root.right = deep(right)
        return root
    }
    return deep(nums)
};
var findMaxNumber = function (arr) {
  let max = -Infinity, index = 0
  for (let i = 0; i < arr.length; i++) {
    if (arr[i] > max) {
      max = arr[i]
      index = i;
    }
  }
  return [max, index];
}

优化

上面的版本虽然容易理解,但是每次都生成了新的数组,这样很消耗空间和时间,所以进行了优化,利用索引来获取需要的范围,只需要对初始的数组进行修改即可,而节约了构造数组的消耗

js 复制代码
class TreeNode {
    constructor(val) {
        this.val = val;
        this.left = null;
        this.right = null;
    }
}
var constructMaximumBinaryTree = function (nums) {
  const deep = (nums, left, right) => {
    if (left > right) return null;
    let max = -Infinity, index = -1;
    for (let i = left; i <= right; i++) {
      if (nums[i] > max) {
        max = nums[i]
        index = i;
      }
    }
    let root = new TreeNode(max);
    root.left = deep(nums, left, index - 1)
    root.right = deep(nums, index + 1, right)
    return root;
  }
  return deep(nums, 0, nums.length - 1)
};
相关推荐
向日的葵006几秒前
vue路由(二)
前端·javascript·vue.js·vue
ejinxian6 分钟前
Angular v22 正式发布:Signal Forms、Angular Aria 和 AI 开发工具全面生产化
前端·javascript·angular.js
珊瑚里的鱼6 分钟前
【动态规划】按摩师
算法·动态规划
Fms_Sa7 分钟前
贪心算法-背包问题
算法·贪心算法·c#
大雨淅淅13 分钟前
【机器人】ROS2 机械臂控制(MoveIt2)从入门到实战
人工智能·python·神经网络·学习·算法·机器学习·机器人
sugar__salt21 分钟前
基于Prompt的NLP项目实战:ES6模块化落地开发指南
javascript·自然语言处理·prompt·es6
小雨下雨的雨24 分钟前
通过鸿蒙PC Electron框架技术完成-井字棋游戏 - 实现详解
前端·javascript·游戏·华为·electron·鸿蒙
冰暮流星36 分钟前
javascript建立对象之构造函数
开发语言·javascript·ecmascript
智者知已应修善业43 分钟前
【51单片机0.1秒计时到21.0时点亮LED】2024-1-5
c++·经验分享·笔记·算法·51单片机
apcipot_rain1 小时前
计科八股20260606——二叉树、PCA、图深度学习、进程上下文、C语言预编译、文件读写、单精度浮点数
c语言·数据结构·算法·pca·图神经网络