LeetCode 104. Maximum Depth of Binary Tree

谁说胖子不能爱 提交于 2019-11-26 11:59:25

用递归的办法

思路1,从下往上累加

    int maxDepth(TreeNode* root) {
        if(!root)
            return 0;
        return max(maxDepth(root->left), maxDepth(root->right))+1;
    }

思路2,从上往下累加

    void helper(TreeNode* p, int dep, int& depth){
        if(!p)
            return;
        
        depth=max(depth,dep+1);        
        helper(p->left, dep+1, depth);
        helper(p->right, dep+1, depth);
    }
    
    int maxDepth(TreeNode* root) {        
        int depth=0;
        helper(root, 0,depth);
        return depth;
    }

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!