平衡二叉树的定义
平衡二叉树(Balanced Binary Tree)是具有以下性质的二叉树:它是一棵空树或它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一棵平衡二叉树。
判断一棵二叉树是否平衡(C++)
#include <iostream>
#define NULL 0
using namespace std;
template<class T>
struct BTNode
{
T data;
BTNode<T> *lChild, *rChild;
BTNode();
BTNode(const T &val, BTNode<T> *childL = NULL, BTNode<T> *childR = NULL)
{
data = val;
lChild = childL;
rChild = childR;
}
BTNode<T>* CopyTree()
{
BTNode<T> *nl, *nr, *nn;
if(&data == NULL)
{
return NULL;
}
nl = lChild->CopyTree();
nr = rChild->CopyTree();
nn = new BTNode<T>(data, nl, nr);
return nn;
}
};
template<class T>
BTNode<T>::BTNode()
{
lChild = rChild = NULL;
}
template<class T>
class BinaryTree
{
public:
BTNode<T> *root;
BinaryTree();
~BinaryTree();
void DestroyTree();
BTNode<T>* MakeTree(const T &element, BTNode<T> *l, BTNode<T> *r)
{
root = new BTNode<T> (element, l, r);
if(root == NULL)
{
cout << "Failure for applying storage address, system will close the process." << endl;
exit(1);
}
return root;
}
private:
void Destroy(BTNode<T> *&r);
};
template<class T>
BinaryTree<T>::BinaryTree()
{
root = NULL;
}
template<class T>
BinaryTree<T>::~BinaryTree()
{
DestroyTree();
}
template<class T>
void BinaryTree<T>::DestroyTree()
{
Destroy(root);
}
template<class T>
void BinaryTree<T>::Destroy(BTNode<T> *&r)
{
if(r != NULL)
{
Destroy(r->lChild);
Destroy(r->rChild);
delete r;
r = NULL;
}
}
template<class T>
int isBalanced(BTNode<T> *r)
{
if(!r)
{
return 0;
}
int left = isBalanced(r->lChild);
int right = isBalanced(r->rChild);
if((left >= 0) && (right >= 0) && ((left - right) <= 1) && ((left - right) >= -1))
{
return (left < right) ? (right + 1) : (left + 1);
}
else
{
return -1;
}
}
void main()
{
BTNode<char> *b, *c, *d, *e, *f, *g;
BinaryTree<char> a;
b = a.MakeTree('F', NULL, NULL);
c = a.MakeTree('E', NULL, NULL);
d = a.MakeTree('D', b, NULL);
e = a.MakeTree('C', NULL, NULL);
f = a.MakeTree('B', d, c);
g = a.MakeTree('A', f, e);
if(isBalanced(a.root) >= 0)
{
cout << "This IS a balanced binary tree." << endl;
}
else
{
cout << "This is NOT a balanced binary tree." << endl;
}
}
// Output:
/*
This is NOT a balanced binary tree.
*/
分享到:
相关推荐
数据结构课程设计-平衡二叉树的操作!本人以前做的就是这个,非常不错的,不过就只有代码哦!
数据结构-平衡二叉树的操作演示.docx
2015广工数据结构实验--平衡二叉树(包含源码和实验报告
利用平衡二叉树实现一个动态查找表。 (1)实现动态查找表的三种基本功能:查找、插入和删除。 (2)初始时,平衡二叉树为空树,操作界面给出查找、插入和删除三种操作供选择。每种操作均要提示输入关键字。在查找...
数据结构C语言版-平衡二叉树.doc
实现的平衡二叉树的基本功能还有分裂和合并的功能
广工数据结构课程设计大作业-平衡二叉树-Java实现(数据结构期末)
平衡二叉树课设平衡二叉树课设
(1) 构建一个平衡二叉树并实现创建、插入、查找、删除、销毁等操作。每种操作均提示输入关键字。每次插入或删除一个结点后,更新平衡二叉树的显示。 (2) 平衡二叉树的显示采用凹入表现形式。 (3)输入的...
广工数据结构课程设计——平衡二叉树操作的演示 内含源代码、可执行程序以及相应的说明文档 实验的功能包括: [实现提示] (1) 初始,平衡二叉树为空树,操作界面给出查找、插入和删除三种操作供选择。每种操作均要...
本文本是广东工业大学数据结构课设平衡二叉树的演示的报告,最后的等级是优秀。文本里面对于选做提高的部分内容都采用了两种方法实现。文档里面有些过程的演示由于涉及到个人信息我删除了,你们可以下载下来后可以...
C语言编写的 数据结构 平衡二叉树 演示、含课程设计报告 多种输出平衡二叉树格式
数据结构——中序遍历平衡二叉树
广工数据结构实验——平衡二叉树 里面含有:源代码、可执行程序、说明文档
广工数据结构课程设计(平衡二叉树的演示),包含报告源代码
我们的数据结构实验课里的关于平衡二叉树的代码。 包含二叉树的插入和平衡,先序、中序和后序遍历。 基本全是按照清华的那本教科书里的思路写的,清晰易懂。
平衡二叉树各种操作的递归实现
实现了二叉查找树的查找、插入...实现了平衡二叉树(AVL树)的查找、插入、删除和迭代遍历的完整功能,插入时的各种旋转操作按照经典数据结构教材实现,并有详细的注释和说明。删除操作和相关旋转方法有单独描述文档。
数据结构课程设计&平衡二叉树的实现;数据结构课程设计&平衡二叉树的实现;数据结构课程设计&平衡二叉树的实现
平衡二叉树的非递归实现