创建和遍历二叉树(基本操作)

// test12.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include
<iostream>
using namespace std;

typedef 
struct BiThrNode{
    
char data;
    
struct BiThrNode *lchild, *rchild;
}BiThrNode, 
*BiThrTree;

/**
createBiTree(t)
    cin>>ch
    if(ch=='@') 
        t=NULL
    else
        t->data=ch
        createBiTree(t->lchild)
        createBiTree(t->rchild)
*/
void createBiTree(BiThrTree& t){//先序生成二叉树
    char ch;
    cin
>>ch;
    
if(ch=='@') t=NULL;
    
else {
        t
=(BiThrNode*)malloc(sizeof(BiThrNode));
        t
->data=ch;
        createBiTree(t
->lchild);
        createBiTree(t
->rchild);
    }
}

/**
PreOrderTraverse(t, visit)
    if(t)
        visit(t->data)
        PreOrderTraverse(t->lchild, visit)
        PreOrderTraverse(t->rchild, visit)
*/
void PreOrderTraverse(BiThrTree t, void(*visit)(char)){//先序遍历,打印成广义表的格式
    if(t){
        visit(t
->data);

        
if(t->lchild){
            cout
<<"(";
            PreOrderTraverse(t
->lchild,visit);
            cout
<<",";
        }

        
if(t->rchild){
            
if(!(t->lchild)) cout<<"(,";
            PreOrderTraverse(t
->rchild,visit);
            cout
<<")";
        }
        
        
if(t->lchild && !(t->rchild)) cout<<")";
    }
}

/**
InOrderTraverse(t, visit)
    if(t)
        InOrderTraverse(t->lchild,visit)
        visit(t->data)
        InOrderTraverse(t->rchild,visit)
*/
void InOrderTraverse(BiThrTree t, void(*visit)(char)){ //中序遍历,带括号
    if(t){
        
if(t->lchild){
            cout
<<"(";
            InOrderTraverse(t
->lchild, visit);
            cout
<<")";
        }
        visit(t
->data);
        
if(t->rchild){
            cout
<<"(";
            InOrderTraverse(t
->rchild,visit);
            cout
<<")";
        }
    }
}

void printElement(char d){cout<<d;}

int main()
{    
    BiThrTree t;
    createBiTree(t);
    
//InOrderTraverse(t, printElement);
    PreOrderTraverse(t,printElement);
    system(
"pause");
}

posted on 2008-10-22 15:58 deep2 阅读(326) 评论(0)  编辑 收藏 引用 所属分类:


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


<2008年10月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

导航

统计

常用链接

留言簿(1)

随笔分类

随笔档案

搜索

最新评论

阅读排行榜

评论排行榜