【亡羊补牢】挑战数据结构与算法 第47期 LeetCode 111. 二叉树的最小深度(二叉树)
发布日期:2021-06-29 14:34:25 浏览次数:3 分类:技术文章

本文共 1117 字,大约阅读时间需要 3 分钟。

仰望星空的人,不应该被嘲笑

题目描述

给定一个二叉树,找出其最小深度。

最小深度是从根节点到最近叶子节点的最短路径上的节点数量。

说明: 叶子节点是指没有子节点的节点。

示例:

给定二叉树 [3,9,20,null,null,15,7],    3   / \  9  20    /  \   15   7

返回它的最小深度 2.

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/minimum-depth-of-binary-tree
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题思路

dfs,对于当前节点,判断一下是否有左右孩子,有的话就取左右孩子得到的最小深度,如果只有左孩子,递归左孩子,只有有孩子,则递归右孩子。到子节点时,直接返回 1

/** * Definition for a binary tree node. * function TreeNode(val) { *     this.val = val; *     this.left = this.right = null; * } *//** * @param {TreeNode} root * @return {number} */var minDepth = function(root) {
let dfs = (root) => {
if(root == null) return 0; // 左右孩子都有,取左右孩子的最小值 if(root.left && root.right){
return 1 + Math.min(dfs(root.left),dfs(root.right)); }else if(root.left){
return 1 + dfs(root.left); }else if(root.right){
return 1 + dfs(root.right); } return 1; } return dfs(root);};

最后

文章产出不易,还望各位小伙伴们支持一波!

往期精选:

小伙伴们可以在Issues中提交自己的解题代码,🤝 欢迎Contributing,可打卡刷题,Give a ⭐️ if this project helped you!

,方便小伙伴阅读玩耍~

学如逆水行舟,不进则退

转载地址:https://chocolate.blog.csdn.net/article/details/108795798 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:【亡羊补牢】挑战数据结构与算法 第48期 LeetCode 104. 二叉树的最大深度(二叉树)
下一篇:【亡羊补牢】挑战数据结构与算法 第46期 LeetCode 101. 对称二叉树(二叉树)

发表评论

最新留言

哈哈,博客排版真的漂亮呢~
[***.90.31.176]2024年04月21日 12时41分09秒