力扣labuladong一刷day3共4题

力扣labuladong一刷day3共4题

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

题目链接:https://leetcode.cn/problems/maximum-depth-of-binary-tree/

思路:按照拉不拉东的思路,二叉树分为两类问题,一类是遍历一边就可以解决的,另一类是通过分解问题计算答案。第一种用全局变量记录,第二章靠返回值接收子问题的答案。

想获得最大深度就是在进入一个结点之前深度加1,离开结点之后深度减1,遍历到当前节点如果是叶子节点就收集答案。

java 复制代码
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--;
    }
}

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

java 复制代码
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. 二叉树的直径

题目链接:https://leetcode.cn/problems/diameter-of-binary-tree/

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

java 复制代码
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. 二叉树的前序遍历

题目链接:https://leetcode.cn/problems/binary-tree-preorder-traversal/

思路:前序遍历模板。

java 复制代码
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. 计算二叉树的深度

题目链接:https://leetcode.cn/problems/er-cha-shu-de-shen-du-lcof/

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

java 复制代码
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;
    }
}
相关推荐
violet-lz9 分钟前
数据结构八大排序:堆排序-从二叉树到堆排序实现
数据结构·算法
十八岁讨厌编程19 分钟前
【算法训练营 · 补充】LeetCode Hot100(上)
算法·leetcode
爱学习的小鱼gogo23 分钟前
python 单词搜索(回溯-矩阵-字符串-中等)含源码(二十)
开发语言·数据结构·python·矩阵·字符串·回溯·递归栈
_殊途25 分钟前
项目开发手册-开发流程
java
想要AC的sjh39 分钟前
华为Java专业级科目一通过心得
java·开发语言·华为
一条星星鱼40 分钟前
从0到1:如何用统计学“看透”不同睡眠PSG数据集的差异(域偏差分析实战)
人工智能·深度学习·算法·概率论·归一化·睡眠psg
浮灯Foden42 分钟前
算法-每日一题(DAY18)多数元素
开发语言·数据结构·c++·算法·leetcode·面试
青鱼入云1 小时前
Java 11对集合类做了哪些增强?
java
小欣加油1 小时前
leetcode 844 比较含退格的字符串
算法·leetcode·职场和发展
小龙报1 小时前
《算法每日一题(1)--- 第31场蓝桥算法挑战赛》
c语言·开发语言·c++·git·算法·学习方法