本課題要求遞歸法創建一棵樹,並完成前,中,后續遍歷。
樹選擇用遞歸的方法,可以很容易做到前中后續的遍歷
創建一個樹的結構體,有內容data,與左孩子和右孩子指針
typedef struct node{
char data;
struct node *lchild;
struct node *rchild;
}BTnode;
創建樹的函數,如果遇到#則代表無輸入
按照先左孩子,后右孩子的方式輸入
void CreateBtree(BTnode *&T){
char data;
cin>>data;
T=new BTnode;
if(data=='#'){
T=NULL;
return ;
}
T->lchild=NULL;
T->rchild=NULL;
T->data=data;
CreateBtree(T->lchild);
CreateBtree(T->rchild);
}
前序遍歷
void PreOrder(BTnode *&T){ if(T){ cout<<T->data<<" "; PreOrder(T->lchild); PreOrder(T->rchild); } }
中序遍歷
void InOrder(BTnode *&T){
if(T){
InOrder(T->lchild);
cout<<T->data<<" ";
InOrder(T->rchild);
}
}
后序遍歷
void PostOrder(BTnode *&T){
if(T){
PostOrder(T->lchild);
PostOrder(T->rchild);
cout<<T->data<<" ";
}
}
輸入一個如圖所示的二叉樹

如圖輸出:

整體代碼展示:
#include<iostream>
using namespace std;
typedef struct node{
char data;
struct node *lchild;
struct node *rchild;
}BTnode;
void CreateBtree(BTnode *&T){
char data;
cin>>data;
T=new BTnode;
if(data=='#'){
T=NULL;
return ;
}
T->lchild=NULL;
T->rchild=NULL;
T->data=data;
CreateBtree(T->lchild);
CreateBtree(T->rchild);
}
void PreOrder(BTnode *&T){
if(T){
cout<<T->data<<" ";
PreOrder(T->lchild);
PreOrder(T->rchild);
}
}
void InOrder(BTnode *&T){
if(T){
InOrder(T->lchild);
cout<<T->data<<" ";
InOrder(T->rchild);
}
}
void PostOrder(BTnode *&T){
if(T){
PostOrder(T->lchild);
PostOrder(T->rchild);
cout<<T->data<<" ";
}
}
int main(){
BTnode *T;
CreateBtree(T);
cout<<"前綴遍歷:";
PreOrder(T);
cout<<endl;
cout<<"中綴遍歷:";
InOrder(T);
cout<<endl;
cout<<"后綴遍歷:";
PostOrder(T);
}
