补 实验五:树和二叉树实验

其实实验课时已做好,一直忘记发


《数据结构》实验五:   树和二叉树实验

一..实验目的

     巩固树和二叉树的相关知识,特别是二叉树的相关内容。学会运用灵活应用。

1.回树和二叉树的逻辑结构和存储方法,清楚掌握树和二叉树的遍历操作。

2.学习树的相关知识来解决实际问题。

3.进一步巩固程序调试方法。

4.进一步巩固模板程序设计。

二..实验内容

1.自己设计一个二叉树,深度最少为4,请递归算法分别用前序、中序、后序遍历输出树结点。

#ifndef bitree_h_H
#define bitree_h_H
struct binode
{
 char data;
 binode *lchild,*rchild;
};
class bitree
{
public:
 bitree(){root=creat(root);}
 ~bitree(){release(root);}
 void preorder(){preorder(root);}
 void inorder(){inorder(root);}
 void postorder(){postorder(root);}
private:
 binode *root;
 binode *creat(binode *bt);
    void release(binode *bt);
    void preorder(binode *bt);
 void inorder(binode *bt);
 void postorder(binode *bt);
};
#endif
 #include<iostream>
using namespace std;
#include"bitree.h"
binode *bitree::creat(binode *bt)
{
 char ch;
 cout<<"please input"<<endl;
 cin>>ch;
 if(ch=='#')return NULL;
 else
 {
  bt=new binode;
  bt->data=ch;
  bt->lchild=creat(bt->lchild);
  bt->rchild=creat(bt->rchild);
 }
 return bt;
}
void bitree::release(binode *bt)
{
 if(bt!=NULL) 
 {
  release(bt->lchild);
  release(bt->rchild);
  delete bt;
 }
}
void bitree::preorder(binode *bt)
{
 if(bt==NULL)return;
 else
 {
  cout<<bt->data <<" ";
  preorder(bt->lchild);
  preorder(bt->rchild);
 }
}
void bitree::inorder(binode *bt)
{
 if(bt==NULL)return;
 else
 {
  inorder(bt->lchild);
  cout<<bt->data <<" ";
  inorder(bt->rchild);
 }
}
void bitree::postorder(binode *bt)
{
 if(bt==NULL)return;
 else
 {
postorder(bt->lchild);
     postorder(bt->rchild);
     cout<<bt->data <<" ";
 }
}
void main()
{
 bitree A;
 cout<<"-------preorder--------"<<endl;
 A.preorder();
 cout<<endl;
 cout<<"-------inorder---------"<<endl;
 A.inorder();
 cout<<endl;
 cout<<"------postorder--------"<<endl;
 A.postorder();
 cout<<endl;
}


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值