程序笔记   发布时间:2022-07-16  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了二叉树的最小深度大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

二叉树的最小深度

 

 详细思路

dfs,形参root,求出root树的最小深度,
 
精确定义
dfs,形参root,求出root树的最小深度,root为叶节点边界返回1,如果根结点的左右子树一棵有而一棵为空,最小深度绝对不是1,而要看非空的子树的最小深度,所以只递推非空节点,而不递推空节点
class Solution {
public:
    int minDepth(TreeNode* root) {
        if(!root)return 0;
        return dfs(root);
    }

    int dfs(TreeNode*root){
        if(!root->left&&!root->right)return 1;
        if(root->left&&!root->right)return 1+dfs(root->left);
        else if(!root->left&&root->right)return 1+dfs(root->right); 
        else return 1+min(dfs(root->left),dfs(root->right));
    }
};
踩过的坑
根结点不是叶节点,也就是说

二叉树的最小深度

 

的最小深度是5不是1
root为空是不应该发生的,root为叶节点就一定要返回1,
如果根结点的左右子树一棵有而一棵为空,最小深度绝对不是1,而要看非空的子树的最小深度

 

大佬总结

以上是大佬教程为你收集整理的二叉树的最小深度全部内容,希望文章能够帮你解决二叉树的最小深度所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。