代码随想录算法训练营DAY16 | 二叉树 (3)

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

题目链接:104.二叉树的最大深度icon-default.png?t=N7T8https://leetcode.cn/problems/maximum-depth-of-binary-tree/

思路:采用后序遍历递归求解。

class Solution {
    int ans = 0;
    public int maxDepth(TreeNode root) {
        if(root == null){
            return 0;
        }
        int left = maxDepth(root.left);
        int right = maxDepth(root.right);
        int depth = 1 + Math.max(left,right);
        return depth;
    }
}
/**
 * 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;
 *     }
 * }
 */

二、LeetCode 111 二叉树的最小深度

题目链接:111.二叉树的最小深度icon-default.png?t=N7T8https://leetcode.cn/problems/minimum-depth-of-binary-tree/

思路:左右孩子均为空才是叶子节点,才可以计算深度。

class Solution {
    public int minDepth(TreeNode root) {
        if(root == null){
            return 0;
        }
        //左
        int left = minDepth(root.left);
        //右
        int right = minDepth(root.right);
        //中
        //左子树为空、右子树不空的情况(非叶子节点)
        if(root.left == null && root.right != null){
            return 1 + right;
        }
        //右子树为空,左子树不空的情况
        if(root.left != null && root.right == null){
            return 1 + left;
        }
        return 1 + Math.min(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;
 *     }
 * }
 */

三、LeetCode 222 完全二叉树的节点个数

题目链接:222.完全二叉树的节点个数icon-default.png?t=N7T8https://leetcode.cn/problems/count-complete-tree-nodes/description/

思路:分别计算左右子树节点个数,再相加。

class Solution {
    public int countNodes(TreeNode root) {
        if(root == null){
            return 0;
        }
        //分别计算左右子树节点个数 再相加
        int left = countNodes(root.left);
        int right = countNodes(root.right);
        return left + right + 1;
    }
}
/**
 * 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;
 *     }
 * }
 */

四、今日小结

        偷得浮生半日闲~

相关推荐

  1. 的遍历——代码随想算法训练Day14

    2024-02-09 10:22:01       29 阅读
  2. 代码随想算法训练day14|的遍历

    2024-02-09 10:22:01       47 阅读
  3. 代码随想算法训练|day15相关推荐

    2024-02-09 10:22:01       34 阅读
  4. 代码随想训练16day5

    2024-02-09 10:22:01       13 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-09 10:22:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-09 10:22:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-09 10:22:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-09 10:22:01       20 阅读

热门阅读

  1. Git入门

    Git入门

    2024-02-09 10:22:01      32 阅读
  2. 单片机精进之路-2led灯闪烁

    2024-02-09 10:22:01       36 阅读
  3. Rust语言入门(第3篇)

    2024-02-09 10:22:01       30 阅读
  4. Rust安装——Win10

    2024-02-09 10:22:01       33 阅读
  5. QT styleSheet——控件设置样式表

    2024-02-09 10:22:01       41 阅读
  6. AcWing 829. 模拟队列

    2024-02-09 10:22:01       32 阅读
  7. 深入挖掘AI应用场景的存储架构

    2024-02-09 10:22:01       35 阅读
  8. Python中数字和字符串的最佳实践(下)

    2024-02-09 10:22:01       29 阅读
  9. CDN缓存404、403状态码

    2024-02-09 10:22:01       28 阅读