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

建设网站找什么王也道长冷酷头像

建设网站找什么,王也道长冷酷头像,cms系统开源,免费网站下载软件免费📝个人主页:五敷有你 🔥系列专栏:算法分析与设计 ⛺️稳中求进,晒太阳 题目 给定一个不重复的整数数组 nums 。 最大二叉树 可以用下面的算法从 nums 递归地构建: 创建一个根节点,其值为 nums 中的最…

       📝个人主页:五敷有你      

 🔥系列专栏:算法分析与设计

⛺️稳中求进,晒太阳

题目

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

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

返回 nums 构建的 最大二叉树 

示例

示例 1:

输入: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 的节点。- 空数组,无子节点。

示例 2:

输入:nums = [3,2,1]
输出:[3,null,2,null,1]

思路

用递归实现,construct(int[] nums,int left,int right)。

表示对数组nums从nums[left]到nums[right] 的元素构建一棵树。我们首先找到这一区间中的最大值,记为nums[best].这样就确定了根节点的值。随后我们就可以进行递归:

左子树为  construct(nums,left,best−1);

右子树为 construct(nums,left,best−1)

当递归到一个无效的区间(即 left>right)时,便可以返回一棵空的树.

代码实现

/*** 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;for(int i=left;i<=right;i++){best=nums[best]>nums[i]?best:i;}TreeNode node=new TreeNode();node.val=nums[best];node.left=func(nums,left,best-1);node.right=func(nums,best+1,right);return node;}
}

运行结果

时间复杂度O(n^2)

空间复杂度O(n)

http://www.yayakq.cn/news/702723/

相关文章:

  • 宁夏建设工程招标投标管理中心网站遵义做网站哪个公司最好
  • 网站建设手机网站开发项目经理岗位职责
  • 购买一个网站需要多少钱?wordpress foxlogin
  • 怎么 从头开始建设一个网站视频服务器
  • 外贸 静态网站 怎么做山西网站建设服务公司
  • 建设网站需要api吗百度seo查询收录查询
  • 网站开发seo要求备案的域名可以做盗版电影网站吗
  • 如何实现网站开发广州seo团队
  • 公司名称大全及最新清远网站关键词优化
  • wordpress手机网站模版网站建设几大类型
  • 网站编排页面莱芜网站优化排名
  • 让人家做网站需要问什么问题软件技术主要学什么就业前景
  • 有的网站显示正在建设中wordpress微信机器人破解版
  • 河北建设厅网站修改密码在哪wordpress 返回顶部代码
  • 重庆做网站公司贴吧建设大型的企业网站费用
  • 怎样在凡科网站做网页微信小程序开发费用
  • 深圳的设计网站太原模板建站软件
  • 哪里长沙网站开发百度导航地图下载
  • 西数网站管理助手 伪静态商城类网站建设步骤
  • 自己开一个网站怎么赚钱网络公司网站建设彩铃样本
  • 网站优化 英文wordpress学做网站
  • 手机网站支持微信支付类似云盘 网站开发
  • 网站建设商城网站app开发一个多少钱
  • 哪个网站ppt模板免费下载怎么建立和设计公司网站
  • 想让网站的文章都被收录怎么做链接交换公司
  • centos7做网站响应式网站制作价格
  • 网站符号wordpress数据表优化
  • 全国好的深圳网站设计wordpress searchform
  • 海珠高端网站建设松原做网站
  • 最全的网站大全高端网站定制开发深圳