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

网站 数据报表如何做网站后台发布文章

网站 数据报表如何做,网站后台发布文章,大庆市建设局网站刘东,企业信息查询系统官网上海题目 给定一棵二叉树的根节点 root ,请找出该二叉树中每一层的最大值。 示例1: 输入: root [1,3,2,5,3,null,9] 输出: [1,3,9] 解释:1/ \3 2/ \ \ 5 3 9 示例2: 输入: root [1,2,3] 输出: [1,3] 解释:1/ \2 3示例3&#xff…

题目

给定一棵二叉树的根节点 root ,请找出该二叉树中每一层的最大值。

示例1:

输入: root = [1,3,2,5,3,null,9]
输出: [1,3,9]
解释:1/ \3   2/ \   \  5   3   9 

示例2:

输入: root = [1,2,3]
输出: [1,3]
解释:1/ \2   3

示例3:

输入: root = [1]
输出: [1]

示例4:

输入: root = [1,null,2]
输出: [1,2]
解释:      1 \2     

示例5:

输入: root = []
输出: []

提示:

  • 二叉树的节点个数的范围是 [0,104]
  • -231 <= Node.val <= 231 - 1

注意:本题与主站 515 题相同: 力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

LCR 044. 在每个树行中找最大值 - 力扣(LeetCode)

题解

思路一:DFS,用先序遍历深搜,并用 curHeight来标记遍历到的当前节点的高度。当遍历到 时判断是否更新该层节点的最大值。

代码:

class Solution {public List<Integer> largestValues(TreeNode root) {if (root == null) return new ArrayList<Integer>();List<Integer> res = new ArrayList<Integer>();dfs(res, root, 0);return res;}public void dfs(List<Integer> res, TreeNode root, int curHeight) {if (curHeight == res.size()) //到新的一层,加进来第一个值res.add(root.val);else res.set(curHeight, Math.max(res.get(curHeight), root.val));if (root.left != null) dfs(res, root.left, curHeight + 1);if (root.right != null) dfs(res, root.right, curHeight + 1);}
}

思路二:BFS,层序遍历,一层一层扩展,用 maxVal来标记该层节点的最大值。当前层处理完成之后,maxVal即为当前层的最大值。

代码:

class Solution {public List<Integer> largestValues(TreeNode root) {if (root == null) return new ArrayList<Integer>();List<Integer> res = new ArrayList<Integer>();Queue<TreeNode> queue = new ArrayDeque<TreeNode>();queue.offer(root);while (!queue.isEmpty()) {int len = queue.size();//当前len确保了len--到0时,刚好处理完当前层int maxVal = Integer.MIN_VALUE;while (len > 0) {TreeNode t = queue.poll();len--;maxVal = Math.max(maxVal, t.val);if (t.left != null) queue.offer(t.left);if (t.right != null) queue.offer(t.right);}res.add(maxVal);}return res;}
}

tips:关于值传递和引用传递。在Java中用的是值传递。在其它方法里面改变引用类型的值都是通过引用改变的,当传递引用对象的时候,传递的是复制的引用的对象句柄,是复制过的,也就是在内存中复制了一个句柄,这两个句柄指向同一个对象,所以改变这个句柄对应的空间的数据会影响到外部的变量虽然是复制的,但是指向的是同一个地址,当你把这个句柄指向其它对象的引用时并不会改变原来的值(例如String),因为用的是复制过的句柄。

http://www.sczhlp.com/news/69118/

相关文章:

  • 帮别人做ppt挣钱的网站wordpress站点登陆
  • 南京建设网站公司上海网安网站建设
  • 营销型网站重要特点是岳阳网站定制
  • 我想建个网站网站怎么建域名网盟推广费用
  • 做健身网站开题报告公司网站建设费计入什么费用
  • 个人网站开发人员小程序注册失败怎么办
  • Sqlite在低版本Centos系统启动失败问题解决
  • AAA
  • 制作网页小程序seo搜索优化招聘
  • 买域名和服务器一般要多少钱郴州网站seo外包
  • 万网主机网站建设数据库怎么弄网页编辑实训报告
  • 微信怎么做网站郑州新闻发布会直播
  • dz插件网站和自己做的网站区别做网站要学的知识
  • 南通网站定制公司wordpress 添加内容
  • 蓝色系 网站衡水网站设计公司哪家好
  • 网站的开发环境搭建网络环境
  • 青海网站建设公司电话天津电商网站开发
  • Burnside/Plya
  • presence_penalty, frequency_penalty以及repetition_penalty
  • qoj4420. Range Reachability Query
  • 建俄语网站哪个公司最好微信公众平台账号注册
  • 做移动网站点击软件软文营销实施背景
  • 中山网页网站设计模板博客一号WordPress
  • 网站首页被k多久恢复比较好的建站网站
  • Atcoder 杂题
  • 中国建设银行客户端下载官方网站电子商务网站建设一般流程图
  • 响应式网站开发价格个人网页包括哪些内容
  • 沈阳网站建设优秀公司建设银行个人网上银行入口
  • 昆明网站建设询力鼎科技四种软件开发模型
  • 中国建设银行的网站设计做网站建设最好学什么