C++实现二叉树

#include <iostream>
using namespace std ;
class Tree
{
    public :
        int number ; 
        class Tree *left ; 
        class Tree *right ;
        void insert_tree(class Tree **header , int number) ;
        void print_tree(class Tree *header , int lever) ;
        void front(class Tree *header) ;
        void middle(class Tree *header) ;
        void back(class Tree *header) ;   
};

int main()
{
    Tree tree ;
    Tree *header = NULL ; 
    int i ;
    int buffer[10] ;
    for(i = 0 ; i < 10 ; i++)
    {
        buffer[i] = rand()%100 ;
    }
     for(i = 0 ; i < 10 ; i++)
    {
        tree.insert_tree(&header , buffer[i]) ;  
    }
    tree.print_tree(header,0);
    cout << endl<< "前序遍历: " <<endl ;
    tree.front(header) ; 
    cout << endl << "中序遍历: "<< endl ;
    tree.middle(header) ; 
    cout << endl << "后序遍历: " << endl ;
    tree.back(header);  
    getchar(); 
}

void Tree::insert_tree(class Tree **header , int number)
{
    Tree *New = NULL ;
    New = new Tree[10] ;
    if(NULL == New)
	   return ;
	New->number = number ; 
    New->left = NULL ; 
    New->right = NULL ; 
	Tree **link = header ; 
	Tree *cur ; 
	while(cur = *link)
	{ 
		if(New->number < cur->number)
			link = &(cur->left) ;
		else
			link = &(cur->right) ; 
	}
	*link = New ;  
}
void Tree::print_tree(Tree *header , int lever)
{
    if(header == NULL)
		return ; 
	
	print_tree(header->right , lever+1);
	int i ; 
	for(i = 0 ; i < lever ; i++)
		cout<<'\t';
	cout << header->number << endl;
	print_tree(header->left , lever+1);
}

void Tree::front(class Tree *header)
{
    if(header == NULL)
		return ; 
	cout <<' '<<header->number ;
	front(header->left);
	front(header->right);
}

void Tree::middle(class Tree *header)
{
    if(header == NULL)
		return ; 
	middle(header->left);
    cout<<' '<< header->number ;
	middle(header->right);
}

void Tree::back(class Tree *header)
{
    if(header == NULL)
		return ; 
	back(header->left);
	back(header->right);
	cout <<' '<<header->number ;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值