原题链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台
题目描述
给定一个二叉树,判断它是否是高度平衡的二叉树。
本题中,一棵高度平衡二叉树定义为:
一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1 。
样例1:
输入
root = [3,9,20,null,null,15,7]
输出
true
样例2:
输入
root = [1,2,2,3,3,null,null,4,4]
输出
false
/*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:int getDeep(TreeNode* node) {if(node == nullptr) return 0;else{int left = 0,right = 0;if(node->left) left = getDeep(node->left);if(node->right) right = getDeep(node->right);return max(left,right)+1;}}bool isBalanced(TreeNode* root) {int left = 0,right = 0;if (root == nullptr) return true;if(root->left) left = getDeep(root->left);if(root->right) right = getDeep(root->right);if(abs( left - right )<=1){return isBalanced(root->left) && isBalanced(root->right);}else{return false;}return true;}
};