二叉树的创建及三种方式的遍历-C++实现

   建议读者在阅读代码前先详细了解二叉树的三种遍历方式(前序,中序,后序),下面直接给出代码。

#include <iostream>
using namespace std;
struct node//定义一个结构体来作为节点 
{
	char ch;//节点中的数据 
	node *left;//左儿子 
	node *right;//右儿子 
};
node *root;//根节点 
void creatT(node* &T)
{
	//按照先序遍历输入二叉树,输入样例代码末尾有给出 
	char cha;
	if(cin>>cha&&cha!='#')
	{
		T=new node;
		T->ch=cha;
		creatT(T->left);
		creatT(T->right);
	}
	else {T=NULL;return;}
};
void pretravel(node* &T)//先序遍历 
{
	if(T)
	{
		cout<<T->ch;
		pretravel(T->left);
		pretravel(T->right);
	}
}
void intravel(node* &T)//中序遍历 
{
	if(T)
	{
		intravel(T->left);
		cout<<T->ch;
		intravel(T->right);
	}
}
void postravel(node* &T)//后序遍历 
{
	if(T)
	{
		postravel(T->left);
		postravel(T->right);
		cout<<T->ch;
		delete T;//删除相应地址中的数据,防止内存泄漏,一定要在后序遍历函数中使用,否则程序会出错。 
	}
}
int main()
{
	creatT(root);
	cout<<"preorder traversal\n";
	pretravel(root);cout<<'\n';
	cout<<"in-order traversal\n";
	intravel(root);cout<<'\n';
	cout<<"post-order traversal\n";
	postravel(root);
}
/*
D B A # # C # # E # G F # # #
*/

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值