目录
DAY16
104.二叉树的最大深度
给定一个二叉树,找出其最大深度。
二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。
说明: 叶子节点是指没有子节点的节点。
示例: 给定二叉树 [3,9,20,null,null,15,7],
返回它的最大深度 3 。
什么是深度,什么是高度,如何求深度,如何求高度,这里有关系到二叉树的遍历方式。
大家 要先看视频讲解,就知道以上我说的内容了,很多录友刷过这道题,但理解的还不够。
题目链接/文章讲解/视频讲解: 代码随想录
解题思路&代码
思路:
求解二叉树的深度,正常来讲应该采用前序遍历(中左右),一步步向下得到各层的深度,但此处二叉树的深度和高度在数值上是一致的,所以采用后序遍历(左右中)得到各层的高度
class Solution {
public int maxDepth(TreeNode root) {
if (root == null) return 0;
int leftDepth = maxDepth(root.left);//后序遍历分别是左,右,中的处理逻辑
int rightDepth = maxDepth(root.right);//右子树最大高度
return Math.max(leftDepth, rightDepth) +1;/**这个+1,考虑极端情况,
即从null的上一层叶子节点开始模拟,此时leftDepth为0、rightDepth为0,
但最底层的叶子节点高度为1,而且每提高一层,高度+1 */
}
}
111.二叉树的最小深度
给定一个二叉树,找出其最小深度。
最小深度是从根节点到最近叶子节点的最短路径上的节点数量。
说明: 叶子节点是指没有子节点的节点。
示例:
给定二叉树 [3,9,20,null,null,15,7],
返回它的最小深度 2.
先看视频讲解,和最大深度 看似差不多,其实 差距还挺大,有坑。
题目链接/文章讲解/视频讲解:代码随想录
解题思路&代码
思路:
主要是最小深度必须找到左右节点都为null的叶子节点,而不是直接取最小就行(与最大深度的差异就在这里)
class Solution {
public int minDepth(TreeNode root) {
if (root == null) { //递归三要素,确定递归函数的参数和返回值,确定终止条件,确定单层递归的逻辑
return 0;
}
int leftDepth = minDepth(root.left); //确定好左、右、中的处理逻辑,终止条件,会不断循环,所以不用怕极端情况
int rightDepth = minDepth(root.right);
if (root.left == null ) { /**最小深度是从根节点到最近叶子节点的最短路径上的节点数量
(叶子节点是指没有子节点的节点),所以对左节点为null,右节点不为null的情况会持续遍历 */
return rightDepth + 1;
}
if (root.right == null ) {
return leftDepth + 1;
}
// 左右节点都不为null
return Math.min(leftDepth, rightDepth) +1;
}
}
222.完全二叉树的节点个数
给出一个完全二叉树,求出该树的节点个数。
示例 1:
- 输入:root = [1,2,3,4,5,6]
- 输出:6
需要了解,普通二叉树 怎么求,完全二叉树又怎么求
题目链接/文章讲解/视频讲解:代码随想录
解题思路&代码
思路:
普通二叉树
首先按照普通二叉树的逻辑来求。
这道题目的递归法和求二叉树的深度写法类似, 而迭代法,二叉树:层序遍历登场! (opens new window)遍历模板稍稍修改一下,记录遍历的节点数量就可以了。
递归遍历的顺序依然是后序(左右中)。
完全二叉树只有两种情况,情况一:就是满二叉树,情况二:最后一层叶子节点没有满。
对于情况一,可以直接用 2^树深度 - 1 来计算,注意这里根节点深度为1。
对于情况二,分别递归左孩子,和右孩子,递归到某一深度一定会有左孩子或者右孩子为满二叉树,然后依然可以按照情况1来计算。
class Solution {
/**
* 针对完全二叉树的解法,这一步的终止条件比较复杂,不仅是节点为null,并且还得判断子二叉树是不是完全二叉树,是的话就返回2^depth - 1
*
* 满二叉树的结点数为:2^depth - 1
*/
public int countNodes(TreeNode root) {
if (root == null) return 0;
TreeNode left = root.left;
TreeNode right = root.right;
int leftDepth = 0, rightDepth = 0; // 这里初始为0是有目的的,为了下面求指数方便
while (left != null) { // 求左子树深度
left = left.left;
leftDepth++;
}
while (right != null) { // 求右子树深度
right = right.right;
rightDepth++;
}
if (leftDepth == rightDepth) {
return (2 << leftDepth) - 1; // 注意(2<<1) 相当于2^2,所以leftDepth初始为0
}
return countNodes(root.left) + countNodes(root.right) + 1;//不满足满二叉树就往下继续递归,返回左节点个数+右节点个数+当前节点
}
}