题解 | #JZ79 平衡二叉树#

平衡二叉树

http://www.nowcoder.com/practice/8b3b95850edb4115918ecebdf1b4d222

//递归获取深度时进行BBT判断

class Solution {
public:
    int depth(TreeNode *pRoot, bool &isBBT) {
        if (!pRoot || !isBBT) return 0;    //节点为空或已非BBT
        
        int leftDepth = depth(pRoot->left, isBBT);    //左子树深度
        int rightDepth = depth(pRoot->right, isBBT);    //右子树深度
        
        if (abs(leftDepth-rightDepth) > 1)    //若深度相差大于1,则不是BBT
            isBBT = false;
        
        return 1 + max(leftDepth, rightDepth);    //子树深度+1为当前树深度
    }
    
    bool IsBalanced_Solution(TreeNode* pRoot) {
        bool isBBT = true;
        
        depth(pRoot, isBBT);    //深度遍历的同时进行BBT判断
        
        return isBBT;
    }
};
全部评论

相关推荐

07-03 11:02
中山大学 C++
字节刚oc,但距离九月秋招很近了有两段互联网实习,非腾讯字节。不敢赌转正,现在在纠结去还是不去如果实习俩月离职会有什么后果吗
阿城我会做到的:不去后悔一辈子,能否转正取决于ld的态度,只要他不卡,答辩就是走流程,个人觉得可以冲一把
投递字节跳动等公司8个岗位
点赞 评论 收藏
分享
白火同学:能。我当初应届沟通了1200,收简历50,面试10左右吧,加油投吧
投了多少份简历才上岸
点赞 评论 收藏
分享
自学java狠狠赚一...:骗你点star的,港卵公司,记得把star收回去
点赞 评论 收藏
分享
今天 11:42
江西农业大学 C++
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务