[LC]111题 二叉树的最小深度 (递归)
2024-09-01 15:42:11
①题目
给定一个二叉树,找出其最小深度。
最小深度是从根节点到最近叶子节点的最短路径上的节点数量。
说明: 叶子节点是指没有子节点的节点。
示例:
给定二叉树 [3,9,20,null,null,15,7],
返回它的最小深度 2.
②思路
使用深度优先搜索
③代码
class Solution {
public int minDepth(TreeNode root) {
if (root == null) {
return 0;
}
if ((root.left == null) && (root.right == null)) {
return 1; //当“当前结点”为叶子结点时,返回1,退出本次递归,并且跳过了17行min_depth的自加。
} int min_depth = Integer.MAX_VALUE; //因为要求最小深度,所以一开始把它设置为最大的int整数,这与530题题解的第三行异曲同工,也与783的低4行类似。
if (root.left != null) {
min_depth = Math.min(minDepth(root.left), min_depth);
}
if (root.right != null) {
min_depth = Math.min(minDepth(root.right), min_depth);
}
return min_depth + 1; //每递归一次,只要不是第3行,第6行的情况,那么最终都会在这里让min_depth加个1。
}
}
//我们用深度优先搜索来解决这个问题。
//这是我看的别人的答案。
④学到的东西
1、判断叶子结点,就是直接判断左右孩子为空不。
2、要学会这种第17行给min_depth自加的行为。
3、再次深化第10行在自己脑子里的记忆。
最新文章
- ASP.NET MVC5 网站开发实践(二) Member区域 - 用户部分(2)用户登录、注销
- kafka入门:简介、使用场景、设计原理、主要配置及集群搭建(转)
- Ubuntu 修改 ssh 登录后的欢迎信息
- j.APR连接器整体框图(含SSL实现分析)
- sqlserver分区表实践:对时间分区表自动进行管理
- 一键清除cvs/svn 目录
- 我用过的Linux命令之chmod
- JQuery中实现Ajax
- Git相关操作四
- git打包
- Webpack 2 视频教程 011 - Webpack2 中加载 CSS 的相关配置与实战
- p2p项目,自己期望太高了。
- LeetCode &; Q283-Move Zeroes-Easy
- pig 的chararry类型不能用比较运算符comparison operator
- Config Server高可用
- nginx的信号量
- iTOP-4412开发板_驱动_adc驱动升级和测试例程
- js变量以及其作用域
- Sublime Text下使用SFTP/FTP插件
- 模拟日历计算 poj1008