二叉树的链式存储

一、实验目的

1、   熟练理解树和二叉树的相关概念,掌握的存储结构和相关操作实现;

2、   掌握树的顺序结构的实现;

3、   学会运用树的知识解决实际问题

二、 实验内容

1、自己确定一个二叉树(树结点类型、数目和结构自定)利用链式存储结构方法存储。实现树的构造,并完成:

1)用前序遍历、中序遍历、后序遍历输出结点数据;

2)以合理的格式,输出各个结点和双亲、孩子结点信息;

3)输出所有的叶子结点信息;


源代码如下:

#include<iostream>  
using namespace std;  
  
template <class T>  
struct BiNode  
{  
    T data;  
    BiNode<T> *lchild,*rchild;  
};  
  
template <class T>  
class Bitree  
{  
    public:  
        Bitree() { root=Creat(root); } 
        ~Bitree() { Release(root); }  
        void Preorder() { Preorder(root); }  
        void Inorder() { Inorder(root); }  
        void Postorder() { Postorder(root); }   
        void Leverorder();   
        void message(T x){ message(root,x); } 
    private:  
        BiNode<T> *root; 
        BiNode<T> *Creat(BiNode<T> *bt); 
        void Release (BiNode<T> *bt);  
        void Preorder (BiNode<T> *bt);  
        void Inorder (BiNode<T> *bt);  
        void Postorder (BiNode<T> *bt);  
        void message(BiNode<T> *bt,T x);  
        void Parent(BiNode<T> *bt,T x);  
};  
  
template <class T>  
void Bitree<T>::Preorder(BiNode<T> *bt)  
{  
    if(bt==NULL) return;   
    else {  
        cout<<bt->data<<" ";    //访问根结点的数据域  
        Preorder(bt->lchild);  //前序递归遍历左子树  
        Preorder(bt->rchild);  //前序递归遍历右子树  
    }  
}  
  
template <class T>  
void Bitree<T>::Inorder(BiNode<T> *bt)  
{  
    if(bt==NULL) return;   
    else {  
        Inorder(bt->lchild);  //中序递归遍历左子树  
        cout<<bt->data<<" ";    //访问根结点的数据域  
        Inorder(bt->rchild);  //中序递归遍历右子树  
    }  
}  
  
template <class T>  
void Bitree<T>::Postorder(BiNode<T> *bt)  
{  
    if(bt==NULL) return;  
    else {  
        Postorder(bt->lchild);  //后序递归遍历左子树  
        Postorder(bt->rchild);  //后序递归遍历右子树  
        cout<<bt->data<<" ";    //访问根结点的数据域  
    }  
}  
  
template <class T>  
void Bitree<T>::Leverorder()  
{  
    front = rear =-1; 
    if(root == NULL) return; 
    Q[++rear] = root;  
    while(front!=rear)  
    {  
        q=Q[++front];  
        cout<<q->data;  
        if(q->lchild !=NULL) Q[++rear]=q->lchild;  
        if(q->rchild !=NULL) Q[++rear]=q->rchild;  
    }  
}  
  
template <class T>  
BiNode<T> *Bitree<T>::Creat(BiNode<T> *bt)  
{  
    char ch;  
    cout<<"前序遍历输入扩展二叉树的各个结点数据,输入#为空 :"<<endl;  
    cin>>ch;  
    if(ch=='#') bt=NULL;  
    else {  
        bt= new BiNode<T>; bt->data = ch;  
        bt->lchild=Creat(bt->lchild);  
        bt->rchild=Creat(bt->rchild);  
          
    }  
    return bt;  
}  
  
template <class T>  
void Bitree<T>::Release(BiNode<T> *bt)  
{  
    if(bt!=NULL)
	{  
        Release(bt->lchild);  
        Release(bt->rchild);  
        delete bt;  
    }  
}  
  
template <class T>  
void Bitree<T>::message(BiNode<T> *bt,T x)  
{  
    int data;  
    if(bt==NULL) return;  
    else{  
        if(bt->data==x)
		{  
            cout<<"结点"<<bt->data<<endl;  
            if(bt->lchild!=NULL) cout<<"左孩子为:"<<bt->lchild->data<<endl;    
            else cout<<"无左孩子"<<endl;    
            if(bt->rchild!=NULL) cout<<"右孩子为:"<<bt->rchild->data<<endl;  
            else cout<<"无右孩子"<<endl;    
            if(bt==root)  cout<<"该结点为根,无双亲"<<endl;    
            else   Parent(root,x);  
        }  
        else{    
             message(bt->lchild,x);    
             message(bt->rchild,x);    
        }  
    }  
}  
  
template<class T>    
void Bitree<T>::Parent(BiNode<T> *bt,T x)    
{    
    if(bt==NULL) return;    
    else    
    {    
        if(bt->lchild->data==x||bt->rchild->data==x)
			cout<<"双亲为:"<<bt->data<<endl;    
        else{    
            Parent(bt->lchild,x);    
            Parent(bt->rchild,x);    
        }    
    }    
}  
  
void main()  
{  
    char x; int q;  
    Bitree<char>s;  
    cout<<"前序遍历二叉树:"<<endl;  
    s.Preorder();  
    cout<<endl;  
    cout<<"中序遍历二叉树:"<<endl;  
    s.Inorder();  
    cout<<endl;  
    cout<<"后序遍历二叉树:"<<endl;  
    s.Postorder();  
    cout<<endl;  
    cout<<"输出结点信息:"<<endl;  
    for(int i=0;i=1;i=q)
	{  
        cout<<"请输入需要查询的结点元素"<<endl;  
        cin>>x;  
        s.message(x);  
        cout<<"是否需要继续查询结点元素?"
			<<endl<<"是:1      否:0"<<endl;  
        cin>>q;  
        if (q==0) break;  
    }  
}  

运行结果如下:



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值