剑指offer之【平衡二叉树】

题目:

  平衡二叉树

链接:

  https://www.nowcoder.com/practice/8b3b95850edb4115918ecebdf1b4d222?tpId=13&tqId=11192&rp=2&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking

题目描述:

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

思路:

  根据计算二叉树深度的方法进行改进,只需深度遍历一次,从叶节点向跟节点方向行进。

代码:

 1 class Solution {
 2 public:
 3     bool IsBalanced_Solution(TreeNode* pRoot)
 4     {
 5         int deep;
 6         return DFS(pRoot,deep);
 7 
 8 
 9     }
10     bool DFS(TreeNode* root,int & deep){
11         if(root == nullptr){
12               deep = 0;
13             return true;
14         }
15         int ld,rd;
16         if(DFS(root->left,ld)&& DFS(root->right,rd)){
17             if(abs(rd-ld)<=1){
18                 deep = max(ld,rd)+1;
19                 return true;
20             }
21         }
22         return false;
23     }
24 };

 

posted @ 2017-06-05 15:24  我是畅游海  阅读(113)  评论(0编辑  收藏  举报