判断二叉树是否平衡需检查每个节点左右子树高度差不超过1。定义TreeNode结构后,通过递归实现后序遍历,设计checkHeight函数计算子树高度并标记不平衡情况(返回-1),isBalanced函数调用checkHeight判断结果是否不为-1。该方法时间复杂度O(n),空间复杂度O(h),避免重复计算,可提前终止,适用于实际开发与面试场景。测试示例显示其正确性与高效性。

在C++中判断二叉树是否平衡,核心是检查每个节点的左右子树高度差是否不超过1。所谓平衡二叉树(如AVL树),是指任意节点的左右子树高度之差的绝对值 ≤ 1。
struct TreeNode {
int val;
TreeNode *left;
TreeNode *right;
TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};
int checkHeight(TreeNode* root) {
if (root == nullptr) return 0;
int leftHeight = checkHeight(root->left);
if (leftHeight == -1) return -1; // 左子树不平衡
int rightHeight = checkHeight(root->right);
if (rightHeight == -1) return -1; // 右子树不平衡
if (abs(leftHeight - rightHeight) > 1) return -1; // 当前节点不平衡
return max(leftHeight, rightHeight) + 1; // 返回当前高度
}
bool isBalanced(TreeNode* root) {
return checkHeight(root) != -1;
}
TreeNode* root = new TreeNode(1);
root->left = new TreeNode(2);
root->right = new TreeNode(3);
root->left->left = new TreeNode(4);
调用 isBalanced(root) 将返回 true。
基本上就这些。用递归配合高度检测,既能准确判断又效率高。
以上就是c++++中如何判断二叉树是否平衡_c++二叉树平衡判断方法的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号