110. Balanced Binary Tree
欢迎fork and star:Nowcoder-Repository-github
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.
解析
class Solution_110 {
public:
int getHeight(TreeNode* root)
{
if (!root)
{
return 0;
}
int left = getHeight(root->left);
int right = getHeight(root->right);
return (left > right) ? (left + 1):(right + 1);
}
bool isBalanced(TreeNode *root) {
if (!root)
{
return true;
}
// 不应该用<=1,return true,这样就提前返回了
//if (abs(getHeight(root->left) - getHeight(root->right)) > 1) {
// return false;
//}
//递归:自顶向下
return abs(getHeight(root->left) - getHeight(root->right) <= 1) && isBalanced(root->left) && isBalanced(root->right);
}
// method2
bool isBalanced1(TreeNode *root) {
int depth = 0;
return isBalanced_helper(root, depth);
}
bool isBalanced_helper(TreeNode *root, int &depth) {
if (root == NULL){
depth = 0;
return true;
}
int left, right;
if (isBalanced_helper(root->left, left) && isBalanced_helper(root->right, right)){
if (abs(left - right) <= 1){
depth = 1 + max(left, right);
return true;
}
}
return false;
}
};
题目来源
C/C++基本语法学习
STL
C++ primer