当前位置: 首页 > news >正文

Leetcode 654:最大二叉树

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

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

返回 nums 构建的 最大二叉树 

 public static TreeNode constructMaximumBinaryTree(int[] nums) {TreeNode root=traversal(nums,0,nums.length);return root;}public static TreeNode traversal(int[] nums,int begin ,int end){if(end-begin<1){return null;}if(end-begin==1){return new TreeNode(nums[begin]);   //数组中只有一个节点}//1.先找到最大值和对应角标int max=nums[begin];int index=begin;for(int i=begin+1;i<end;i++){if(nums[i]>max){max=nums[i];index=i;}}TreeNode root=new TreeNode(max);  //创建根节点//划分左右子树root.left=traversal(nums,begin,index);   //构建左子树root.right=traversal(nums,index+1,end);   //构建右子树return root;}

http://www.lryc.cn/news/365205.html

相关文章:

  • uniapp小程序src引用服务器图片时全局变量与图片路径拼接
  • 比较PWM调光和无极调光
  • 【高校科研前沿】新疆生地所陈亚宁研究员团队在GeoSus发文:在1.5°C和2°C全球升温情景下,中亚地区暴露于极端降水的人口增加
  • 使用 OKhttp3 实现 智普AI ChatGLM HTTP 调用(SSE、异步、同步)
  • 智慧校园教学模式的崛起:优化学习体验
  • ffmpeg视频编码原理和实战-(5)对编码过程进行封装并解决丢帧问题
  • halo进阶-主题插件使用
  • 资深开发推荐的IDEA 插件
  • 数学题目系列(一)|丑数|各位和|埃氏筛|欧拉筛
  • k8s学习--Secret详细解释与应用
  • 功能问题:如何防止接口重复请求?
  • 系统架构设计师【第5章】: 软件工程基础知识 (核心总结)
  • 嵌入式Linux系统编程 — 2.2 标准I/O库:检查或复位状态
  • pESC-HIS是什么,怎么看?-实验操作系列-2
  • 树形表/树形数据接口的开发
  • 二叉树的镜像--c++【做题记录】
  • redis安裝启动
  • 为什么Java中的main方法必须是public static void的?
  • shell的编程方式
  • 前端面试项目细节重难点(已工作|做分享)想(八)
  • Loguru,一个 Python 日志神器
  • C++ 反转单词
  • Apache Doris 基础 -- 数据表设计(表索引)
  • 资源描述框架的用途及实际应用解析
  • 工业级物联网边缘网关解决方案-天拓四方
  • 认识微服务,认识Spring Cloud
  • 电脑设置密码怎么设置?让你的电脑更安全!
  • 搜维尔科技:SenseGlove Nova2使用主动接触反馈来模拟手掌的感觉,结合力反馈和振动触觉反馈,使其成为市场上第一款具有手掌反馈的无线触觉手套
  • 基于Python的实验室管理系统的设计与实现(论文+源码)_kaic
  • Windows系统WDS+MDT网络启动自动化安装