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

剑指Offer || 044.在每个树行中找最大值

题目

给定一棵二叉树的根节点 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.lryc.cn/news/197595.html

相关文章:

  • ESP32网络开发实例-UDP数据发送与接收
  • 液压自动化成套设备比例阀放大器
  • 专业144,总分440+,上岸西北工业大学827西工大信号与系统考研经验分享
  • JQuery - template.js 完美解决动态展示轮播图,轮播图不显示问题
  • CC2540和CC2541的区别简单解析
  • Java8 新特性之Stream(八)-- Stream的collect()与Collectors的联合运用
  • SpringBoot基础详解
  • 学会Docker之---应用场景和基本操作
  • C++_linux下_非阻塞键盘控制_程序暂停和继续
  • SQL AND, OR and NOT(与,或不是运算符)
  • Python网络编程之Socket(套接字)
  • 金山终端安全系统V9.0 SQL注入漏洞复现
  • Radius OTP完成堡垒机登录认证 安当加密
  • ROS opencv 人脸识别
  • 文心一言 4.0 ERNIE-Bot 4.0 :ERNIE-Bot 4.0 大模型深度测试体验报告
  • 华为OD机考B卷 | 100分】阿里巴巴找黄金宝箱(JAVA题解——也许是全网最详)
  • 请求转发和重定向区别
  • JS如何判断对象为空?以及各自的缺点。
  • 同城代驾开源版小程序开发
  • 【Python机器学习】零基础掌握ShrunkCovariance协方差估计
  • 精神科常用评估量表汇总,建议收藏!
  • Python之切片
  • OpenCV显示中文(python)
  • k8s-18 认证授权
  • WebAPI+EF连接SQL Server数据库
  • maven-plugin-shade 详解1
  • C#中LinkedList、Queue<T>和Stack<T>的使用
  • 流程图如何制作?好用的11款流程图软件盘点!
  • windows本地文件上传linux 或 linux输入rz命令后出现receive.**B0100000023be50
  • C# CodeFormer Inpainting 人脸填充