C++二叉树结构的建立和操作

本文介绍了如何在C++中建立和操作二叉树,包括初始化、查找、添加结点、计算深度、显示结点数据、清空及遍历(按层、先序、中序、后序)等操作,提供了完整的代码示例。
摘要由CSDN通过智能技术生成

二叉树是数据结构中的树的一种特殊情况,有关二叉树的相关概念,这里不再赘述,如果不了解二叉树相关概念,建议先学习数据结构中的二叉树的知识点。

准备数据

定义二叉树结构操作中需要用到的变量及数据等。

#define MAXLEN 20				//最大长度
typedef char DATA;				//定义元素类型
struct 	CBTType			                //定义二叉树结点类型 
{
	DATA data;			        //元素数据 
	CBTType * left;				//左子树结点指针 
	CBTType * right;			//右子树结点指针 
};

定义二叉树结构数据元素的类型DATA以及二叉树结构的数据结构CBTType。结点的具体数据保存在一个姐都DATA中,而指针left用来指向左子树结点,指针right用来指向右子树结点


初始化二叉树

初始化二叉树,将一个结点设置为二叉树的根结点。

CBTType * InitTree()
{
	CBTType * node;
	if(node = new CBTType)		//申请内存 
	{
		cout<<"请先输入一个根节点数据:"<<endl;
		cin>>node->data;
		node->left=NULL;
		node->right=NULL;
		if(node!=NULL)			//如果二叉树结点不为空 
		{
			return node;		
		} else
		{
			return NULL;
		}
	}
	return NULL;
}

首先申请一个结点,然后用户输入根结点 的数据,并将左子树和右子树的指针置为空,即可完成二叉树的初始化工作。


查找结点

查找结点就是遍历二叉树中的每一个节点,逐个比较数据,当找到目标数据时将返回该数据所在结点的指针。

CBTType *TreeFindNode(CBTType *treeNode,DATA data)
{
	CBTType *ptr;
	if(treeNode==NULL)
	{
		return NULL;
	}else
	{
		if(treeNode->data==data)
		{
			return treeNode;
		}
		else								//分别向左右子树查找			
		{
			if(ptr=TreeFindNode(treeNode->left,data))		//左子树递归查找 
			{
				return ptr;
			}
			else if(ptr=TreeFindNode(treeNode->right,data))	        //右子树递归查找 
			{
				return ptr;
			}
			else
			{
				return NULL;
			}
		}
	} 
} 
输入参数treeNode为待查找的二叉树的根结点,输入参数data为待查找的结点数据。程序中首先判断根结点是否为空,然后根据数据判断是否为根结点,然后分别向左右子树进行查找,采用递归的方法进行查找,查找到该结点则返回结点对应的指针;如果全都查找不到,则返回NULL。


添加结点

添加结点就是在二叉树中添加结点数据,添加结点时除了要输入结点数据外,还需要指定其父结点,以及添加的结点作为左子树还是右子树。然后将该结点置为其父结点的左子树或者右子树。

void AddTreeNode(CBTType *treeNode)
{
	CBTType *pnode,*parent;
	DATA data;
	char menusel;
	if(pnode=new CBTType)					//分配内存 
	{
		cout<<"输入二叉树结点数据:"<<endl;
		cin>>pnode->data;
		pnode->left=NULL;					//设置左子树为空 
		pnode->right=NULL;					//设置左子树为空 
		cout<<"输入该结点的父结点数据"<<endl;
		cin>>data;
		parent=TreeFindNode(treeNode,data);//查找父结点,获得结点指针 
		if(!parent)
		{
			cout<<"没有找到父结点"<<endl;
			delete pnode;
			return ;
		}
		cout<<"1.添加该结点到左子树;2.添加该结点到右子树。请输入操作对应的数字。"<<endl;
		do
		{
			cin>>menusel;
			if(menusel=='1'||menusel=='2')
			{
				switch(menusel)
				{
					case '1':					//添加结点到左子树 
						if(parent->left)	                //左子树不为空
						{
							cout<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值