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

【目标】

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

【代码实现】

建立二叉树以及实现遍历的操作存放在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;
}

【结果图】

这里写图片描述

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我来为您解答。二叉树是一种非常常见的数据结构,它由一个根节点以及每个节点最多有两个子节点组成。下面是用C++实现二叉树建立遍历的示例代码: ```c++ #include<iostream> using namespace std; // 定义二叉树结点 struct TreeNode{ int val; TreeNode* left; TreeNode* right; TreeNode(int x):val(x),left(NULL),right(NULL){} }; // 创建二叉树 void createTree(TreeNode* &root){ int val; cin>>val; if(val == -1){ // 输入-1表示该节点为空 root = NULL; return; } root = new TreeNode(val); // 创建新节点 createTree(root->left); // 递归创建左子树 createTree(root->right); // 递归创建右子树 } // 前序遍历 void preOrder(TreeNode* root){ if(root == NULL){ return; } cout<<root->val<<" "; // 先输出根节点 preOrder(root->left); // 再遍历左子树 preOrder(root->right); // 最后遍历右子树 } // 中序遍历 void inOrder(TreeNode* root){ if(root == NULL){ return; } inOrder(root->left); // 先遍历左子树 cout<<root->val<<" "; // 再输出根节点 inOrder(root->right); // 最后遍历右子树 } // 后序遍历 void postOrder(TreeNode* root){ if(root == NULL){ return; } postOrder(root->left); // 先遍历左子树 postOrder(root->right); // 再遍历右子树 cout<<root->val<<" "; // 最后输出根节点 } int main(){ TreeNode* root; createTree(root); // 创建二叉树 cout<<"前序遍历结果:"; preOrder(root); // 前序遍历 cout<<endl<<"中序遍历结果:"; inOrder(root); // 中序遍历 cout<<endl<<"后序遍历结果:"; postOrder(root); // 后序遍历 cout<<endl; return 0; } ``` 以上代码中,我们利用递归实现二叉树的创建、前序遍历、中序遍历和后序遍历。其中,createTree函数用于创建二叉树,-1代表该节点为空;preOrder、inOrder和postOrder分别用于前序遍历、中序遍历和后序遍历,输出节点的值即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值