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

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

   #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. asp.net for itextsharp 操作pdf

    今天分享下昨天做的一个东西 asp.net 的文件 zip 批量下载,首先你需要去 到http://dotnetzip.codeplex.com这个站点下载zip 的包,在里面找到 Ionic.Zip ...

  2. 跟我学习dubbo-使用Maven构建Dubbo服务的可执行jar包(4)

    Dubbo服务的运行方式: 1.使用Servlet容器运行(Tomcat.Jetty等)----不可取 缺点:增加复杂性(端口.管理) 浪费资源(内存) 官方:服务容器是一个standalone的启动 ...

  3. asp.net渐变

    简介:第一个参数代表渐变的方向,后面的StartColorStr和End就不用解释了: filter: progid:DXImageTransform.Microsoft.Gradient(Gradi ...

  4. Oracle 学习笔记2:几个入门常用命令

    oracle提供的交互方式有两种:sqlplus(命令行) sqlplusw(图形界面) 进入sqlplus方式:cmd中输入sqlplus 进入sqlplusw方式:cmd中输入sqlplusw 更 ...

  5. 二十、Android -- SDcard文件读取和保存

    背景                                                                                            一些东西可以 ...

  6. 可以伸缩的查询面板 (searchBar)

    最近有这样的需求,一个页面查询条件特别多,一次全部展示出来的话就占用大量的空间,所以分成了两类,简单搜索和高级搜索,当点击高级搜索的时候就会全部显示. 这样就存在一个问题,页面(navTab,dial ...

  7. Python Opearte SQLAlchemy Do Something

    近段时间在看SQLAlchemy,总之万事开头难,但是么办法. Database Urls The create_engine() function produces an Engine object ...

  8. CCNA长语

    思科认证网络支持工程师(Cisco Certified Network Associate_CCNA) 专业英文词汇大全 10BaseT-----原始IEEE802.3标准的一部分,1OBaseT是1 ...

  9. QtPropertyBrowser+vs2010的安装与配置(转)

    这一篇文章有些问题,后又写了一篇,地址是http://www.cnblogs.com/aminxu/p/4552410.html 转自http://blog.csdn.net/jingwenlai_s ...

  10. 移动web开发的一些坑

    类似的题目一搜一大堆,我就不再写那些meta标签类似的内容了,记录一下自己实现中遇到的问题,如果能帮到你,那再好不过了. 1px border的问题,大家能搜到很多方案,但如何选择还是要根据实际情况, ...