C++二叉树遍历递归算法

请编写一个C++程序,完成下列算法:

1、 根据扩展二叉树的前序遍历序列,递归构造二叉树;

2、 以广义表的形式输出二叉树;

3、 验证利用栈实现二叉树后序遍历的非递归算法;

4、 利用队列给出二叉树层次遍历的算法。

二叉树以二叉链表方式存储。

#include<iostream.h>
typedef char ElemType; 
#define stackSize 30
typedef struct BiNode
{
    ElemType data;
    BiNode *lchild, *rchild;
}Bino;
void Creat(BiNode *&root)
{
	 
	 ElemType ch;
	 cin>>ch;
	if(ch=='#')   
	  {root=NULL; }
      else {
        root=new BiNode; 
        root->data=ch;
        Creat(root->lchild); 
        Creat(root->rchild); 
	 } 
}
void InOrder(BiNode *root) //中序遍历
{
  if (root==NULL) return;     
   else
		{
          InOrder(root->lchild); 
          cout<<root->data<<" "; 
          InOrder(root->rchild);
        }
}
void PrinTree(BiNode *root)
{
	if(root==NULL) return;
	else
	{
		cout<<root->data;            
		if(root->lchild != NULL || root->rchild != NULL )
	    {
	    	cout << "(";
	    	PrinTree(root->lchild);       
	    	if(root->rchild != NULL)
	        	cout << ",";
	    	PrinTree(root->rchild); 
	    	cout << ")";
		}
	}
} 
void Postorder(BiNode *root)//栈后序非递归遍历
{
	BiNode *S[stackSize];
	int top=-1;
	BiNode *p=root;
	BiNode *pre=NULL;
	do 
	{
		while (p!=NULL)
		{ S[++top]=p;
		  p=p->lchild;
		}
		if(top>-1)
		{
			p=S[top];
			if(p->rchild!=NULL && p->rchild!=pre)
				p=p->rchild;
			else
			{
				cout<<p->data<<" ";
				pre=p;
				p=NULL;
				top--;
			}
		}
	}while (p!=NULL||top!=-1);
}
void Leveorder(BiNode *root)//队列层序遍历
{
   BiNode *Q[30],*p;
   int front,rear;  
   if(root == NULL) 
	  return;
   front=0;
   rear=0;
   Q[++rear]=root;
   while(front!=rear)
   {
     front++; 
	 p=Q[front];
     cout<<p->data<<" ";
     if(p->lchild!=NULL)
        {
		 rear++;Q[rear]=p->lchild;
		}
     if(p->rchild!=NULL)
         {rear++;Q[rear]=p->rchild;}
   }
}
int main()
{
	BiNode *root;
	cout<<"先序输入,“#”为叶子节点:"<<endl;
	Creat(root);
	cout<<"中序遍历:";
	InOrder(root);
	cout<<endl;
	cout<<"广义表:";
	PrinTree(root);
	cout<<endl;
	cout<<"栈的后序非递归遍历:";
	Postorder(root);
	cout<<endl;
	cout<<"队列的层序遍历:";
	Leveorder(root);
	cout<<endl;
	return 0;
}

  • 3
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值