2023.7.4
平衡二叉树 ,经典题目 。需要利用到之前求二叉树高度的思路。 先定义一个求高度的函数,然后使用递归的方式判断左子树和右子树的高度差是否小于等于1,下面上代码:
class Solution {
public:
int get_length(TreeNode* cur)
{
queue<TreeNode*> que;
int length = 0;
if(cur == nullptr) return length;
que.push(cur);
while(!que.empty())
{
int size = que.size();
length++;
while(size--)
{
TreeNode* node = que.front();
que.pop();
if(node->left) que.push(node->left);
if(node->right) que.push(node->right);
}
}
return length;
}
bool isBalanced(TreeNode* root) {
if(root == nullptr) return true;
return abs(get_length(root->left) - get_length(root->right))<=1 && isBalanced(root->left) && isBalanced(root->right);
}
};
挺经典的题,思路值得借鉴。