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.


判断是不是平衡树,本来的想法是复用求树的高度的那个函数,但是那样的话,其实相当于DFS了树两次,时间浪费。如这样

  1. bool isBalanced(TreeNode *root) {
  2.         if(root==NULL)
  3.             return true;
  4.         int leftheight=maxHeight(root->left);
  5.         int rightheight=maxHeight(root->right);
  6.         return isBalanced(root->left) && isBalanced(root->right) &&(leftheight-rightheight<2 && leftheight-rightheight>-2);
  7.     }
  8.     int maxHeight(TreeNode * root){
  9.         if(root==NULL)
  10.             return 0;
  11.         return 1+std::max(maxHeight(root->left),maxHeight(root->right));
  12.     }

这题最大的亮点是如何在一次递归中返回两个数。可以用返回值返回一个,另一个可以是传一个引用或者全局变量。

  1. int height(TreeNode *root, bool & result){
  2.     if(root==NULL || result==false)
  3.         return 0;
  4.     int l=height(root->left, result);
  5.     int r=height(root->right, result);
  6.     if(abs(l-r)>1)
  7.         result=false;
  8.     return max(l,r)+1;
  9. }

  10. bool isBalanced(TreeNode *root) {
  11.     bool result=true;
  12.     height(root,result);
  13.     return result;
  14. }


<script>window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdMiniList":false,"bdPic":"","bdStyle":"0","bdSize":"16"},"share":{}};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://bdimg.share.baidu.com/static/api/js/share.js?v=89860593.js?cdnversion='+~(-new Date()/36e5)];</script>
阅读(6) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~
评论热议
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值