前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【关关的刷题日记64】Leetcode 110 Balanced Binary Tree

【关关的刷题日记64】Leetcode 110 Balanced Binary Tree

作者头像
WZEARW
发布2018-04-12 10:20:23
4830
发布2018-04-12 10:20:23
举报
文章被收录于专栏:专知专知

关关的刷题日记64 – Leetcode 110 Balanced Binary Tree

题目

Given a binary tree, determine if it is height-balanced.

For this problem, a height-balanced binary tree is defined as a binary tree in which the depth of the two subtrees of every node never differ by more than 1.

题目的意思是给定一个二叉树,判断它是否是平衡树。平衡树的任何一个节点的左右子树的深度差不超过1。

思路

思路:可见判断一棵树是否是平衡树,需要满足两个条件:1、该树的左右子树都是平衡树 2、该树的左右子树的深度差不超过1。判断该树的左右子树是否是平衡树的过程和判断这棵树是否是平衡树的过程一样,采用递归的思路。

代码语言:javascript
复制
代码语言:javascript
复制
class Solution {public:
    int depth(TreeNode* root)
    {
        if (root==nullptr)
            return 0;
        int count=0,left=1,right=1;
        left+=depth(root->left);
        right+=depth(root->right);
        return max(left, right);
    }

    bool isBalanced(TreeNode* root) {
        if(!root)
            return true;
        int l=depth(root->left), r=depth(root->right);
        return (l==r || l==r+1 || l==r-1) && isBalanced(root->left) && isBalanced(root->right); 
    }};

人生易老,唯有陪伴最长情,加油!

以上就是关关关于这道题的总结经验,希望大家能够理解,有什么问题可以在我们的专知公众号平台上交流或者加我们的QQ专知-人工智能交流群 426491390,也可以加入专知——Leetcode刷题交流群(请先加微信小助手weixinhao: Rancho_Fang)。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2017-12-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 专知 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目
  • 思路
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档