二叉树遍历
来源:互联网 发布:模拟人生3 for mac 编辑:程序博客网 时间:2024/06/17 02:43
#include <stdio.h>
#include <stdlib.h>
typedef char TElemType;
typedef struct BiTNode
{
TElemType data;
struct BiTNode *lchild,*rchild;
}BiTNode, *BiTree;
void CreateBiTree(BiTree *T)
{
//按先序次序输入二叉树中结点的值,#代表空树
char ch;
scanf("%c",&ch);
if('#' == ch)
{
*T=NULL;
}
else
{
*T =(BiTNode *)malloc(sizeof(BiTNode));
(*T)->data =ch;
CreateBiTree(&(*T)->lchild);
CreateBiTree(&(*T)->rchild);
}
}
void PrintElement(TElemType e)
{
printf("%c",e);
}
void PreOrderTraverse(BiTree T,void (*visit)(TElemType e))
{
//线序遍历二叉树T的递归算法,对每个元素调用visit方法
if(T)
{
visit(T->data);
PreOrderTraverse(T->lchild, visit);
PreOrderTraverse(T->rchild, visit);
}
}
void InOrderTraverse(BiTree T,void (*visit)(TElemType e))
{
if(T)
{
InOrderTraverse(T->lchild, visit);
visit(T->data);
InOrderTraverse(T->rchild, visit);
}
}
void PostOrderTraverse(BiTree T,void (*visit)(TElemType e))
{
if(T)
{
PostOrderTraverse(T->lchild, visit);
PostOrderTraverse(T->rchild, visit);
visit(T->data);
}
}
int main(void)
{
BiTree T=NULL;
CreateBiTree(&T);
printf("先序遍历:");
PreOrderTraverse(T, PrintElement);
printf("中序遍历:");
InOrderTraverse(T,PrintElement);
printf("后序遍历:");
PostOrderTraverse(T,PrintElement);
}
0 0
- 二叉树遍历、分层遍历
- 遍历二叉树--二叉树
- 【树】遍历二叉树
- 二叉树遍历
- 二叉树遍历
- 二叉树的遍历
- (原创)遍历二叉树
- 二叉树遍历-php
- 查找--遍历二叉树
- 遍历二叉树
- 二叉树遍历规则
- 二叉树的遍历
- 二叉树遍历
- 遍历二叉树
- 二叉树遍历问题
- 二叉树遍历
- 二叉树遍历(zz)
- 二叉树的遍历
- Caused by: org.osgi.framework.BundleException: The activator org.eclipse.m2e.core.ui.internal.M2EUIP
- text-overflow: ellipsis;
- ActiveMQ持久化方式
- imgareaselect图片裁剪、js裁剪案例
- 最优贸易解题报告
- 二叉树遍历
- android程序更换图标无更新解决方案
- astyle使用方法记录
- POJ1979 Red and Black
- 浅析Lua中table的遍历
- Eclipse+tomcat6.0配置SOAP服务的方法
- Mac卸载cocos2d-x
- 500元快速搭建微小企业官网
- 关于ios8定位服务的新增特性