Post

lc.111 求二叉树最小深度(recursion)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
class Solution {
    public:
     int minDepth(TreeNode* root) {
        
        if(root == nullptr) return 0;
        int m1 = minDepth(root->left);//简便记一下
        int m2 = minDepth(root->right);
        
        //分三种情况
        
        //1.左孩子和有孩子都为空的情况,说明到达了叶子节点,直接返回1即可
        if(root->left == nullptr && root->right == nullptr) return 1;
        
        //2.如果左孩子和右孩子其中一个为空,那么需要返回比较大的那个孩子的深度
        //这里其中一个节点为空,说明m1和m2有一个必然为0,所以可以返回m1 + m2 + 1;
        if(root->left == nullptr || root->right == nullptr) return m1 + m2 + 1;
        
        //3.最后一种情况,也就是左右孩子都不为空,返回最小深度+1即可
        return min(m1,m2) + 1; 
    }
}
This post is licensed under CC BY 4.0 by the author.