平衡二叉树
来源:互联网 发布:遥感数据预处理方法 编辑:程序博客网 时间:2024/06/06 08:46
给定一个二叉树,确定它是高度平衡的。对于这个问题,一棵高度平衡的二叉树的定义是:一棵二叉树中每个节点的两个子树的深度相差不会超过1。
给出二叉树 A={3,9,20,#,#,15,7}
, B={3,#,20,15,7}
A) 3 B) 3 / \ \ 9 20 20 / \ / \ 15 7 15 7
二叉树A是高度平衡的二叉树,但是B不是
对于此题我的解题思路是:遍历这棵树上的每个节点,每个节点的左右子树的最大高度的差值不能超过1.这就需要先写一个求某个子树的最大高度的函数。
/**
* Definition of TreeNode:
* class TreeNode {
* public:
* int val;
* TreeNode *left, *right;
* TreeNode(int val) {
* this->val = val;
* this->left = this->right = NULL;
* }
* }
*/
class Solution {
public:
/*
* @param root: The root of binary tree.
* @return: True if this Binary tree is Balanced, or false.
*/
int max(int x,int y)
{
if(x>y)return x;
else return y;
}
int ceshi(TreeNode *root)
{
if(root ==NULL)return 0;
int x,y;
x=ceshi(root->left)+1;
y=ceshi(root->right)+1;
return max(x,y);
}
bool isBalanced(TreeNode * root) {
// write your code here
if(root ==NULL)return true;
int x=ceshi(root->left);
int y=ceshi(root->right);
if(abs(x-y)<=1)
{
return isBalanced(root->left) && isBalanced(root->right);
}
return false;
}
};
- 平衡二叉树平衡法则
- 二叉树--二叉平衡树
- 平衡二叉树的
- 平衡二叉树
- 平衡二叉树
- 平衡二叉树
- 平衡二叉树
- 平衡二叉查找树
- 平衡二叉树 详解
- 平衡二叉树
- 平衡二叉树
- AVL 平衡二叉树
- 平衡二叉树
- 平衡二叉树-红黑树
- 平衡二叉树
- 平衡二叉树
- 平衡二叉树
- 平衡二叉树
- 2、文件相关命令练习
- 学习嵌入式Linux系统开发基础 第一课(Linux系统简介)
- HDU 1052 Tian Ji -- The Horse Racing(贪心)
- 继-初始centos的常见命令行操作
- ACM训练周末总结—9月3日
- 平衡二叉树
- 数据库操作练习12
- Chrome 浏览器中查看 webSocket 连接信息
- dp做题集锦(持续更新中)
- 什么是ORM?
- day4_二级指针做输入输出的三种内存模型
- 堆棋子失败程序(本程序用途:学习c++语法和知识点)
- 文档设置标记
- Vijos1243:生产产品(单调队列优化dp)