LeetCode刷题笔记 111. 二叉树的最小深度

111. 二叉树的最小深度

题目要求

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

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

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

示例:

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

    3
   / \
  9  20
    /  \
   15   7

返回它的最小深度 2.

题解

https://github.com/soulmachine/leetcode

递归

class Solution {
public:
    int minDepth(TreeNode* root,bool hasbrother){
        if(!root) return hasbrother?INT_MAX:0;
        return 1+min(minDepth(root->left,root->right),minDepth(root->right,root->left));
    }
    int minDepth(TreeNode* root) {
        return minDepth(root,false);
    }
};

迭代版

class Solution {
public:
    int minDepth(TreeNode* root) {
        if(!root) return 0;
        int result=INT_MAX;
        stack<pair<TreeNode*,int>> s;
        s.push(make_pair(root,1));

        while(!s.empty()){
            auto node=s.top().first;
            auto depth=s.top().second;
            s.pop();

            if(!node->left&&!node->right) result=min(result,depth);//可能此时在较深的某个节点
            if(node->left&&result>depth) s.push(make_pair(node->left,depth+1));
            if(node->right&&result>depth) s.push(make_pair(node->right,depth+1));
        }
        return result;
    }
};
发布了17 篇原创文章 · 获赞 0 · 访问量 2181

猜你喜欢

转载自blog.csdn.net/g534441921/article/details/104253865