二叉树的建立与遍历(一)(c++实现)

原创 2015年07月06日 16:14:58

【目标】

建立如下所示的一棵二叉树,并且输出其对应的前序遍历、中序遍历、后序遍历。
这里写图片描述

【代码实现】

建立二叉树以及实现遍历的操作存放在Binarytree.h文件中

//Binarytree.h
#ifndef Binarytree_H
#define Binarytree_H
template<class T> class Binarytree;
template<class T>
class TreeNode
{
    friend class Binarytree<T>;
private:
    T data;
    TreeNode<T> *rchild;    //右指针指向右子树
    TreeNode<T> *lchild;   //左指针指向左子树
};
template<class T>
class Binarytree
{
public:
    Binarytree(){root=0;};
    void CreatTree();  //根据实际情况建立二叉树
    void Preorder();
    void Preorder(TreeNode<T> *currentnode); //前序遍历

    void Inorder();
    void Inorder(TreeNode<T> *currentnode); //中序遍历

    void Postorder();
    void Postorder(TreeNode<T> *currentnode); //后序遍历
private:
    TreeNode<T> *root;
};
//-------建立二叉树--------
template<class T>
void  Binarytree<T>::CreatTree()
{
  TreeNode<T> *p1=new TreeNode<T>();
  p1->data='A';
  p1->rchild=0;
  p1->lchild=0;
  root=p1;


  TreeNode<T> *p2=new TreeNode<T>();
  p2->data='B';
  p2->rchild=0;
  p2->lchild=0;
  root->lchild=p2;


  TreeNode<T> *p3=new TreeNode<T>();
  p3->data='C';
  p3->rchild=0;
  p3->lchild=0;
  root->rchild=p3;


  TreeNode<T> *p4=new TreeNode<T>();
  p4->data='D';
  p4->rchild=0;
  p4->lchild=0;
  root->lchild->lchild=p4;


  TreeNode<T> *p5=new TreeNode<T>();
  p5->data='E';
  p5->rchild=0;
  p5->lchild=0;
  root->lchild->rchild=p5;


  TreeNode<T> *p6=new TreeNode<T>();
  p6->data='F';
  p6->rchild=0;
  p6->lchild=0;
  root->rchild->lchild=p6;


  TreeNode<T> *p7=new TreeNode<T>();
  p7->data='G';
  p7->rchild=0;
  p7->lchild=0;
  root->rchild->rchild=p7;

  TreeNode<T> *p8=new TreeNode<T>();
  p8->data='H';
  p8->rchild=0;
  p8->lchild=0;
  root->lchild->lchild->lchild=p8;


  TreeNode<T> *p9=new TreeNode<T>();
  p9->data='I';
  p9->rchild=0;
  p9->lchild=0;
  root->lchild->lchild->rchild=p9;

}
//------递归实现二叉树的前序遍历------
template<class T>
void  Binarytree<T>::Preorder() 
{  
    cout<<"前序遍历(根->左->右)为:";
    Preorder(root); 
}
template<class T>
void  Binarytree<T>::Preorder(TreeNode<T> *currentnode)
{
  if(currentnode)
  {
    cout<<currentnode->data<<" ";
    Preorder(currentnode->lchild);
    Preorder(currentnode->rchild);
  }
}

//------递归实现二叉树的中序遍历------
template<class T>
void  Binarytree<T>::Inorder() 
{  
    cout<<"中序遍历(左->根->右)为:";
    Inorder(root); 
}
template<class T>
void  Binarytree<T>::Inorder(TreeNode<T> *currentnode)
{
  if(currentnode)
  {
    Inorder(currentnode->lchild);
    cout<<currentnode->data<<" ";
    Inorder(currentnode->rchild);
  }
}

//------递归实现二叉树的后序遍历------
template<class T>
void  Binarytree<T>::Postorder() 
{  
    cout<<"后序遍历(左->右->根)为:";
    Postorder(root); 
}
template<class T>
void  Binarytree<T>::Postorder(TreeNode<T> *currentnode)
{
  if(currentnode)
  {
    Postorder(currentnode->lchild);
    Postorder(currentnode->rchild);
    cout<<currentnode->data<<" ";
  }
}
#endif

主程序:

//main.cpp
#include "Binarytree.h"
#include <iostream>
using namespace std;
int main()
{
  Binarytree<char> Tree1;
  Tree1.CreatTree();
  Tree1.Preorder();
  cout<<endl;
  Tree1.Inorder();
  cout<<endl;
  Tree1.Postorder();
  cout<<endl;
  system("pause");
  return 0;
}

【结果图】

这里写图片描述

C++二叉树的建立与遍历

从别处找来几个例子,感觉还可以,同学们拿回去看看吧,有什么地方不懂可以下可以后来实验室问我。//==========================================定义头部 #incl...
  • KarlDoenitz
  • KarlDoenitz
  • 2012年11月13日 20:51
  • 39918

C++类实现二叉树的构建和遍历

#include #include #include using namespace std; /*二叉树的结构体*/ typedef struct BTree { int val; str...
  • u014453898
  • u014453898
  • 2017年02月06日 17:03
  • 998

C++实现二叉树的建立和三种递归遍历

二叉树是一种常见的数据结构,二叉树的遍历也是家常便饭的事了,这里仅仅写出一个完整的可以运行的C++代码来随便建立一个如下图所示的二叉树,建一棵二叉树是实现二叉树各种操作的基础,下面的程序也很简单,这只...
  • JXH_123
  • JXH_123
  • 2014年06月30日 20:16
  • 2715

通过树的先序和中序遍历序列来构造二叉树

通过树的先序和中序遍历序列来构造二叉树
  • zaizai09
  • zaizai09
  • 2014年05月08日 20:39
  • 1427

(编程训练)再回首,数据结构——二叉树的前序、中序、后序遍历(递归)

最近在复习数据结构,顺便看看大一的时候写的代码,看完之后比当初有了更加深刻的体会。        希望这些能提供给初学者一些参考。         在VC++6.0下可运行,当初还写了不少注释。  ...
  • u011694809
  • u011694809
  • 2015年05月28日 11:35
  • 705

二叉树建立与遍历递归操作c++实现

#include #include #include using namespace std; //二叉树的数据类型 typedef char BiTType; ...
  • lwy313722871
  • lwy313722871
  • 2013年12月14日 00:50
  • 1585

C,C++创建二叉树,以及3种遍历

C++ 实现                                                                         ——引用是C++不同于C的地方 ...
  • lby978232
  • lby978232
  • 2012年10月22日 15:57
  • 10640

2015年大二上-数据结构-树和二叉树-2-(1)二叉树的层次遍历

实现二叉树的层次遍历算法,并对用”A(B(D,E(H(J,K(L,M(,N))))),C(F,G(,I)))”创建的二叉树进行测试。   请利用二叉树算法库。 /* *Copyright (...
  • Annpion
  • Annpion
  • 2015年12月24日 11:28
  • 342

实验十二 图的建立与遍历

Description 按邻接矩阵的方法创建图,分别用深度优先和广度优先方法遍历图。 Input 输入的数据有多组 对于每组测试数据第一行为图中点的个数n(0 接下来有m行,每行两个整数a...
  • Kirito_Acmer
  • Kirito_Acmer
  • 2015年04月08日 11:02
  • 774

数据结构之二叉树创建及其遍历

还记得N年想在全盘电脑寻找一个文件,当时看那代码晦涩难懂,后来不了了之,最近复习了下二叉树,现在感觉全盘寻找文件不是想象的那么复杂。 #include #include #include type...
  • hwb_1988
  • hwb_1988
  • 2013年11月13日 11:06
  • 1894
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:二叉树的建立与遍历(一)(c++实现)
举报原因:
原因补充:

(最多只允许输入30个字)