【剑指offer】平衡二叉树

题目描述

输入一棵二叉树,判断该二叉树是否是平衡二叉树。

思路

根据平衡二叉树定义,任意节点左右子数高度不能相差超过1。因此我们需要用到求树的高度的函数,求出左子树跟右子树的高度,然后若左右子树高度差大于1则不是平衡二叉树,否则继续递归判断左右子树是否满足平衡二叉树。

代码

class Solution {
public:
    int get_depth(TreeNode* pRoot){
        if(!pRoot){
            return 0;
        }
        int leftDepth = 1+get_depth(pRoot->left);
        int rightDepth = 1+get_depth(pRoot->right);
        return max(leftDepth,rightDepth);
    }
    bool IsBalanced_Solution(TreeNode* pRoot) {
        if(!pRoot){
            return true;
        }
        int leftDepth = 1+ get_depth(pRoot->left);
        int rightDepth = 1+ get_depth(pRoot->right);
        if(abs(leftDepth-rightDepth) > 1){
            return false;
        }
        //判断左右子树
        return IsBalanced_Solution(pRoot->left) && IsBalanced_Solution(pRoot->right);
    }
};

 

全部评论

相关推荐

02-01 12:05
复旦大学 Java
腾讯的提前批大概率应该是没有笔试的,但是这个时候有相当部分的同学简历估计都没有准备好,没准备好的同学也不用急,大部分都是3月之后开,这个时候开的绝大多数都是神仙打架,问的东西也比较难,打算投递的同学也多看下计算机网络和操作系统,腾讯对这部分的知识问的比较多。另外多刷下牛客的热门题库,刷题注意刷ACM模式,和牛客的周赛题,腾讯有的部门会从这里面出原题。我是@程序员花海关注我,带你了解更多校招资讯!
程序员花海:还没有来得及准备的同学可以看下学习路线:https://www.nowcoder.com/discuss/824693499982315520?sourceSSR=users算法题:https://www.nowcoder.com/feed/main/detail/20e7a999fa04485b88340a274411ca0d?sourceSSR=users八股文:https://www.nowcoder.com/discuss/833102362771251200?sourceSSR=users简历书写方式:https://www.nowcoder.com/discuss/839907820706205696?sourceSSR=users都是以前在牛客发的文章~
软开人,秋招你打算投哪些...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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