当前位置: 首页 > news >正文

[leetcode] 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。depth为该节点的深度初始化为0。

代码如下:

 1 /** 
 2  * Definition for binary tree 
 3  * struct TreeNode { 
 4  *     int val; 
 5  *     TreeNode *left; 
 6  *     TreeNode *right; 
 7  *     TreeNode(int x) : val(x), left(NULL), right(NULL) {} 
 8  * }; 
 9  */ 
10 class Solution {  
11     public:  
12         bool isBalanced(TreeNode *root) {  
13             // Note: The Solution object is instantiated only once and is reused by each test case.  
14             int depth = 0;  
15             return isbalance(root, depth);  
16         }  
17         bool isbalance(TreeNode *root, int &depth)  
18         {  
19             if(root == NULL)  
20             {  
21                 depth = 0;  
22                 return true;  
23             }  
24             int ld,rd;  
25             if( isbalance(root->left,ld) && isbalance(root->right,rd))  
26             {  
27                 if( abs(ld - rd) > 1)  
28                 {  
29                     return false;  
30                 }  
31                 depth = ld > rd ? ld + 1 : rd + 1;  
32                 return true;  
33             }
34             else return false;
35         }  
36 };

 

转载于:https://www.cnblogs.com/jostree/p/3700735.html

相关文章:

  • 运维的我要学开发--Python(4)
  • Ubuntu 14.04配置记录
  • 【笔记】设计模式——装饰者模式
  • IsBadStringPtr、IsBadWritePtr
  • OC语言BLOCK和协议
  • js学习记录
  • C++容器操作
  • .Net 转战 Android 4.4 日常笔记(4)--按钮事件和国际化
  • 引用动态链接库Dll文件 引用失败 未能添加对HD.dll的引用。请确保此文件可访问并且是一个有效的程序集或COM组件...
  • IOS 基于APNS消息推送原理与实现(JAVA后台)--转
  • asp.net解决:当前上下文中不存在名称“Session”
  • thinkphp问题记录phpQuery使用错误
  • CTreeCtrl 父结点联动子结点CheckBox
  • Subversion--Version Control
  • SQLPlus命令详细说明
  • C++类中的特殊成员函数
  • CAP 一致性协议及应用解析
  • CSS居中完全指南——构建CSS居中决策树
  • express + mock 让前后台并行开发
  • FineReport中如何实现自动滚屏效果
  • JavaScript服务器推送技术之 WebSocket
  • Leetcode 27 Remove Element
  • passportjs 源码分析
  • Perseus-BERT——业内性能极致优化的BERT训练方案
  • python学习笔记-类对象的信息
  • Solarized Scheme
  • SpiderData 2019年2月13日 DApp数据排行榜
  • TypeScript实现数据结构(一)栈,队列,链表
  • 分享一个自己写的基于canvas的原生js图片爆炸插件
  • 前端工程化(Gulp、Webpack)-webpack
  • 入手阿里云新服务器的部署NODE
  • 使用 Node.js 的 nodemailer 模块发送邮件(支持 QQ、163 等、支持附件)
  • 应用生命周期终极 DevOps 工具包
  • 鱼骨图 - 如何绘制?
  • #define
  • #控制台大学课堂点名问题_课堂随机点名
  • (简单有案例)前端实现主题切换、动态换肤的两种简单方式
  • (亲测成功)在centos7.5上安装kvm,通过VNC远程连接并创建多台ubuntu虚拟机(ubuntu server版本)...
  • (轉貼)《OOD启思录》:61条面向对象设计的经验原则 (OO)
  • .Net Core和.Net Standard直观理解
  • .NET/C# 检测电脑上安装的 .NET Framework 的版本
  • .NET/C# 使窗口永不获得焦点
  • .NET面试题解析(11)-SQL语言基础及数据库基本原理
  • .NET轻量级ORM组件Dapper葵花宝典
  • .NET设计模式(8):适配器模式(Adapter Pattern)
  • .net下简单快捷的数值高低位切换
  • .NET序列化 serializable,反序列化
  • 。Net下Windows服务程序开发疑惑
  • /var/spool/postfix/maildrop 下有大量文件
  • @Autowired @Resource @Qualifier的区别
  • [【JSON2WEB】 13 基于REST2SQL 和 Amis 的 SQL 查询分析器
  • [16/N]论得趣
  • [ACM] hdu 1201 18岁生日
  • [CISCN2019 华北赛区 Day1 Web5]CyberPunk --不会编程的崽
  • [Django ]Django 的数据库操作