利用链表建立二叉树,完成前序遍历、中序遍历、后序遍历。

  建立二叉树用的是前序遍历建立二叉树:

   #include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<malloc.h> typedef int element;
typedef struct Tree{
struct Tree *lchild,*rchild;
char data;
}*pTree,pNode; //char str[]="ABD#E##FG###CI##H##";
char str[]="ABDH#K###E##CFI###G#J##";
element index=;
//Init a empty tree
element Init_tree(pTree *T)
{
*T=NULL;
printf("init a empty tree\n");
} //build a tree
void Creat_tree(pNode **T)
{
char num;
num=str[index++];
pTree P=NULL;
//P=*T;
if(num=='#')
*T=NULL;
else
{
// if(!(*T))
// exit(OVERFLOW);
(*T)=(pTree)malloc(sizeof(pNode));
//memset(*T,0,sizeof(pNode));
(*T)->data=num;
Creat_tree(&(*T)->lchild);
Creat_tree(&(*T)->rchild);
}
} //pro order traversal
element Pro_trav(pTree T)
{
if(T==NULL)
return ;
printf("pro order traversal data:%c\n",T->data);
Pro_trav(T->lchild);
Pro_trav(T->rchild);
} //midle order traversal
element Mid_trav(pTree T)
{
if(T==NULL)
return;
Mid_trav(T->lchild);
printf("mid order traversal data:%c\n",T->data);
Mid_trav(T->rchild);
} //after traversal
element Aft_trav(pTree T)
{
if(T==NULL)
return;
Aft_trav(T->lchild);
Aft_trav(T->rchild);
printf("after order traversal data:%c\n",T->data);
} element main()
{
pTree T;
T=(pTree)malloc(sizeof(struct Tree));
//Init_tree(&T);
printf("before is ok\n");
Creat_tree(&T);
Pro_trav(T);
Mid_trav(T);
Aft_trav(T);
return ;
}

   输出结果:

 before is ok
pro order traversal data:A
pro order traversal data:B
pro order traversal data:D
pro order traversal data:H
pro order traversal data:K
pro order traversal data:E
pro order traversal data:C
pro order traversal data:F
pro order traversal data:I
pro order traversal data:G
pro order traversal data:J
mid order traversal data:H
mid order traversal data:K
mid order traversal data:D
mid order traversal data:B
mid order traversal data:E
mid order traversal data:A
mid order traversal data:I
mid order traversal data:F
mid order traversal data:C
mid order traversal data:G
mid order traversal data:J
after order traversal data:K
after order traversal data:H
after order traversal data:D
after order traversal data:E
after order traversal data:B
after order traversal data:I
after order traversal data:F
after order traversal data:J
after order traversal data:G
after order traversal data:C
after order traversal data:A

c语言编程之二叉树的更多相关文章

  1. 20191310李烨龙Linux C语言编程基础

    Linux C语言编程基础 任务详情 0. 基于Ubuntu或OpenEuler完成下面的任务(OpenEuler有加分) 1. 选择教材第二章的一节进行编程基础练习(2.10,2.11,2.12,2 ...

  2. C语言编程实现Linux命令——who

    C语言编程实现Linux命令--who 实践分析过程 who命令是查询当前登录的每个用户,它的输出包括用户名.终端类型.登录日期及远程主机,在Linux系统中输入who命令输出如下: 我们先man一下 ...

  3. 个人c语言编程风格总结

    总结一下我个人的编程风格及这样做的原因吧,其实是为了给实验室写一个统一的C语言编程规范才写的.首先声明,我下面提到的编程规范,是自己给自己定的,不是c语言里面规定的. 一件事情,做成和做好中间可能隔了 ...

  4. Linux下C语言编程实现spwd函数

    Linux下C语言编程实现spwd函数 介绍 spwd函数 功能:显示当前目录路径 实现:通过编译执行该代码,可在终端中输出当前路径 代码实现 代码链接 代码托管链接:spwd.c 所需结构体.函数. ...

  5. 混合语言编程:启用CLR(公共语言运行时编译)让C#调用C++

    前言 关于混合C#和C++的编程方式,本人之前写过一篇博客(参见混合语言编程:C#使用原生的Directx和OpenGL),在之前的博客中,介绍了在C#的Winform和WPF下使用原生的Direct ...

  6. Linux基础与Linux下C语言编程基础

    Linux基础 1 Linux命令 如果使用GUI,Linux和Windows没有什么区别.Linux学习应用的一个特点是通过命令行进行使用. 登录Linux后,我们就可以在#或$符后面去输入命令,有 ...

  7. LINUX下C语言编程基础

    实验二 Linux下C语言编程基础 一.实验目的 1. 熟悉Linux系统下的开发环境 2. 熟悉vi的基本操作 3. 熟悉gcc编译器的基本原理 4. 熟练使用gcc编译器的常用选项 5 .熟练使用 ...

  8. 第二章 C语言编程实践

    上章回顾 宏定义特点和注意细节 条件编译特点和主要用处 文件包含的路径查询规则 C语言扩展宏定义的用法 第二章 第二章 C语言编程实践 C语言编程实践 预习检查 异或的运算符是什么 宏定义最主要的特点 ...

  9. 华为C语言编程规范

    DKBA华为技术有限公司内部技术规范DKBA 2826-2011.5C语言编程规范2011年5月9日发布 2011年5月9日实施华为技术有限公司Huawei Technologies Co., Ltd ...

随机推荐

  1. 【JS Note】undefined与null

    在Javascript中有这两种原始类型: Undefined与Null.而这两种原始类型都各自只有一个值,分别是undefined,null. undefined: 1.变量声明后未赋值,则变量会被 ...

  2. 【CSS3】---文本阴影text-shadow

    text-shadow可以用来设置文本的阴影效果. 语法: text-shadow: X-Offset Y-Offset blur color; X-Offset:表示阴影的水平偏移距离,其值为正值时 ...

  3. 瀑布流布局--jQuery写法

    HTML <div id="main"> <div class="box"> <div class="pic" ...

  4. openquery链表删除时报错 “数据提供程序或其他服务返回 E_FAIL 状态”

    DELETE OPENQUERY (VERYEAST_COMPANY_MYSQL_CONN, 'SELECT * FROM company ') WHERE c_userid in(select c_ ...

  5. 北大ACM(POJ1014-Dividing)

    Question:http://poj.org/problem?id=1014 问题点:抽屉原理.dfs.多重背包. Memory: 248K Time: 16MS Language: C++ Res ...

  6. Cocos2d-x 3.x的Windows Phone 8工程

    Cocos2d-x 3.x中我们使用的Cocos2d-x 3.2,它提供了Windows Phone 8平台的支持.下面我们介绍一下在Cocos2d-x 3.2中如何生成Cocos2d-x的Windo ...

  7. iOS中调用系统录音功能及其播放

    最近做的项目中,用到了录音的功能,简单记录一下. 我的想法是:通过重写button的点击事件,来达到录音的目的. /*----------------------------------[录音]--- ...

  8. 10款免费CSS编辑器应对于Linux和Ubuntu

    您是否在使用Linux和Ubuntu的,不知道在哪里可以找到一些优秀且免费的CSS编辑器用于Linux和Ubuntu的?如果你的答案是肯定的,然后停止幻想,开始浏览这个帖子里,我们展示了前10名,并免 ...

  9. js 字符串“123”,变成整数123,不用parseInt 函数

    var s = "123"; console.log(s.charAt(0)*100+s.charAt(1)*10+s.charAt(2)*1);

  10. Android发送请求到不同的Servlet,但都是一个Servlet处理

    错误原因,在Servlet文件中 @WebServlet("/ServletForGETMethod") 与实际的ServletForQUERYMethod 文件名不符. @Web ...