判断一棵树是否为平衡树及求树的高度
来源:互联网 发布:me授权软件.zip 编辑:程序博客网 时间:2024/04/27 22:46
什么是平衡树?所谓平衡树,就是树的任意结点的左子树和右子树的高度之差的绝对值不超过1。
所以判断一棵树是否为二叉树,不难想到可以先求出树的高度,再求出左右子树的高度差来判断,那么就想先求树的高度。
求树的高度可以用递归方法,树的高度其实是返回左右子树中高度较高的那一个,求当前的高度则还要再加1。
1.求树的高度
size_t _Depth(Node* root){if (root == NULL)return 0;//遇到叶子结点就返回if (root->_left == NULL && root->_right == NULL)return 1;size_t left = _Depth(root->_left);size_t right = _Depth(root->_right);return (left) > right ? (left + 1) : (right + 1);}
2.判断树是否为平衡树
//判断是否是平衡二叉树,左右树的高度差不超过1bool _IsBalance(Node* root){if (root == NULL)return true;int left = _Depth(root->_left);int right = _Depth(root->_right);int diff = left - right; //左右高度差if (diff > 1 || diff < -1) return false;return _IsBalance(root->_left) && _IsBalance(root->_right);}
上述方法虽然可以判断出一棵树是否为平衡树,但是由于不停的调用_Depth函数,使得栈帧的开销不断增大,当树的深度较深时,还可能导致栈溢出。
再看效率,每次求树的深度时,都是从当前根节点遍历到叶子结点,所以一个结点会重复遍历多次,显然效率很低。那么如何将每个结点遍历一次就能达到题目的要求呢?不难想到,如果能把高度记录下来,就可以一边遍历一边判断了。而且根据平衡树的定义,只要有一个子树不是平衡树,那也就没有继续再往下判断的必要了。下面的代码将高度用引用的方式保存下来,并且不断更新,效率变得更高。
bool _IsBalance(Node* root, int& depth){if (root == NULL)return true;int leftdepth = 0, rightdepth = 0;//只要有一棵子树不是平衡树,就可以结束递归操作bool left = _IsBalance(root->_left, leftdepth);if (left == false)return false;bool right = _IsBalance(root->_right, rightdepth);if (right == false)return false;if (left && right){int diff = leftdepth - rightdepth;if (diff <= 1 && diff >= -1){depth = leftdepth > rightdepth ? (leftdepth + 1) : (rightdepth + 1);return true;}return false;}}
阅读全文
1 0
- 判断一棵树是否为平衡树及求树的高度
- 平衡二叉树计算高度的同时判断是否平衡
- 求二叉树的最大深度、最小深度、反转二叉树及判断是否为平衡二叉树
- cc150:判断一棵树是否为平衡树
- 判断一棵树是否为平衡二叉树
- 判断一棵树是否为平衡二叉树
- 判断一棵树是否为平衡二叉树
- 判断一棵树是否为平衡二叉树的算法
- 判断二叉树是否平衡,计算树的高度
- C++算法之 判断是否为平衡二叉树 求二叉树的镜像
- 递归求树的深度,判断是否是平衡树
- BinaryTree的高度求解及平衡树判断
- (1)判断是否为完全二叉树 (2)求二叉树的高度
- 【剑指offer】判断二叉树是否平衡(左右子树高度差最多为1)
- 判断二叉树是否为平衡树
- 判断树是否为平衡二叉树
- 判断二叉树是否为平衡树
- 判断树是否为平衡二叉树
- ZooKeeper入门搭建教程
- 开门人和关门人(sort+结构体)
- Zookeeper简单介绍
- awk
- 异步上传文件(formDate)
- 判断一棵树是否为平衡树及求树的高度
- 又见GCD ||HDU2053
- Only the original thread that created a view hierarchy can touch its views
- MySQL存储引擎
- 二重积分极坐标变换
- UISlider的touchUpInSide方法在界面有其他手势的情况下小范围拖动无效问题
- 【maven】maven编译版本和jdk 版本?
- 用Python教你如何“养”一只DHT爬虫
- Qlist