39.Whether_a_Binary_Tree_Is_Balanced
2024/2/2小于 1 分钟约 105 字
// 输入一棵二叉树,判断该二叉树是否是平衡二叉树。
#include <algorithm>
#include <stack>
using namespace std;
struct TreeNode {
int val;
struct TreeNode *left;
struct TreeNode *right;
TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};
class Solution {
public:
bool IsBalanced_Solution(TreeNode *pRoot) {
if (pRoot == nullptr) return true;
int l = depth(pRoot->left), r = depth(pRoot->right);
if (abs(l - r) > 1)
return false;
else
return IsBalanced_Solution(pRoot->left) &&
IsBalanced_Solution(pRoot->right);
}
int depth(TreeNode *root) {
if (root == nullptr) return 0;
return 1 + max(depth(root->left), depth(root->right));
}
};更新日志
2024/2/20 02:59
查看所有更新日志
c9215-于53095-于fc8ba-于8da40-于
