力扣labuladong一刷day3共4题

编程入门 行业动态 更新时间:2024-10-28 16:20:02

<a href=https://www.elefans.com/category/jswz/34/1766191.html style=力扣labuladong一刷day3共4题"/>

力扣labuladong一刷day3共4题

力扣labuladong一刷day3共4题

一、104. 二叉树的最大深度

题目链接:/
思路:按照拉不拉东的思路,二叉树分为两类问题,一类是遍历一边就可以解决的,另一类是通过分解问题计算答案。第一种用全局变量记录,第二章靠返回值接收子问题的答案。
想获得最大深度就是在进入一个结点之前深度加1,离开结点之后深度减1,遍历到当前节点如果是叶子节点就收集答案。

class Solution {int max = 0, deep = 0;public int maxDepth(TreeNode root) {traverse(root);return max;}void traverse(TreeNode root) {if (root == null) return;deep++;if (root.left == null && root.right == null) {max = Math.max(max, deep);}traverse(root.left);traverse(root.right);deep--;}
}

当前本题也可以采用分解子问题的思路,把求树的最大深度问题转换为求子树的最大深度问题。

class Solution {public int maxDepth(TreeNode root) {if (root == null) return 0;int left = maxDepth(root.left);int right = maxDepth(root.right);return Math.max(left, right) + 1;}
}

二、543. 二叉树的直径

题目链接:/
思路:直径指任意两个点之间的边的数量,也就是左右子树深度之和。

class Solution {int max = 0;public int diameterOfBinaryTree(TreeNode root) {traverse(root);return max;}int traverse(TreeNode root) {if (root == null) return 0;int left = traverse(root.left);int right = traverse(root.right);max = Math.max(max, left + right);return Math.max(left, right) + 1;}
}

三、144. 二叉树的前序遍历

题目链接:/
思路:前序遍历模板。

class Solution {List<Integer> list = null;public List<Integer> preorderTraversal(TreeNode root) {list = new ArrayList<>();traverse(root);return list;}void traverse(TreeNode root) {if (root == null) return;list.add(root.val);traverse(root.left);traverse(root.right);}
}

四、LCR 175. 计算二叉树的深度

题目链接:/
思路:问题不大剑指offer上的题目和力扣上一样,重复了和第一题。

class Solution {public int calculateDepth(TreeNode root) {if (root == null) return 0;int left = calculateDepth(root.left);int right = calculateDepth(root.right);return Math.max(left, right) + 1;}
}

更多推荐

力扣labuladong一刷day3共4题

本文发布于:2023-11-16 00:42:40,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1610576.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:力扣   labuladong

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!