#include<stdio.h>
#include<stdlib.h>
#define OK 1
#define ERROR 0
#define OVERFLOW -2
#define True 1
// 定义二叉树的节点类型
typedef struct BiTNode{
char data;
struct BiTNode *lchild; // 定义节点的左孩子指针,有孩子指针
struct BiTNode *rchild;
}BiTNode,*BiTree; //先序遍历构造二叉链表表示对二叉树T int CreateBiTree(BiTree &T)
{
char ch;
scanf("%c",&ch);
fflush(stdin); // 对键盘缓冲区的处理
if(ch=='#'){ //如果输入#,创建空节点
T=NULL;
}else{
if(!(T=(BiTNode*)malloc(sizeof(BiTNode)))){ //申请根节点的空间
printf("申请节点空间失败!!");
exit(OVERFLOW);
}else{
T->data=ch; //生成根节点
CreateBiTree(T->lchild); //构建左子树
CreateBiTree(T->rchild); //构建右子树
}
return OK;
}
return ERROR;
}
//先序遍历二叉树
int DLR(BiTree T)
{ if(T!=NULL) // 如果树不为空
{
printf("%c\n",T->data);
DLR(T->lchild); // 递归遍历
DLR(T->rchild);
}else{
return ERROR; //树为空
}
return OK; // 遍历成功
} //中序遍历二叉树
int LDR(BiTree T)
{ if(T!=NULL)
{
LDR(T->lchild); // 递归遍历
printf("%c\n",T->data);
LDR(T->rchild);
}else{
return ERROR; //树为空
}
return OK; // 遍历成功
} //后序遍历二叉树
int LRD(BiTree T)
{
if(T!=NULL)
{
LRD(T->lchild); // 递归遍历
LRD(T->rchild);
printf("%c\n",T->data);
}else{
return ERROR; //树为空
}
return OK; // 遍历成功
}
// 树的叶子数
void yezi(BiTree T){ if(T!=NULL){
if(!T->lchild&&!T->rchild){ printf("%c\n",T->data); // 打印叶子节点
}
yezi(T->lchild);
yezi(T->rchild);
} }
// 树的深度
int shendu(BiTree T){
int h=,h1,h2;
if(T==NULL)
return h;
else{
h1=shendu(T->lchild);
h2=shendu(T->rchild);
if(h1>=h2) // 最后加的数为树的最深
h=h1+;
else
h=h2+;
}
return h;
} void OperateMenu()
{ printf("\n--------------请选择元素处理方式---------\n\n");
printf("\n注:请输入数字\n");
printf("0>:退出操作\n");
printf("1>:先序遍历二叉树\n");
printf("2>:中序遍历二叉树\n");
printf("3>:后序遍历二叉树\n");
printf("4>:树的叶子节点\n");
printf("5>:树的深度\n");
printf("请选择对元素的处理:"); } void zushi(){
printf("注:此过程为二叉树的建立及其对其的相关操作\n\t以下为树的大致模型\t\n"); printf(" 1 \n");
printf(" / \\ \n");
printf(" 2 3 \n");
printf(" / \\ / \\ \n");
printf(" # # # # \n");
printf("\n 注!!!楼上输入 # 表示无孩子为空\n故输入序列为12##3###\n");
printf("实际形成序列形成的树为为:\n");
printf(" 1 \n");
printf(" / \\ \n");
printf(" 2 3 \n");
}
int main(){
int w=,k,n,boo=;
BiTree T;
printf("请用户选择创建二叉树或退出程序:\n\n");
printf("创建二叉树请输入:'1'\n\n");
printf("退出请选择'0'或 其它!!\n\n");
printf("请选择:");
scanf("%d",&w);
if(w==){
zushi();
printf("\n请输入树节点元素(请回车输入下一个数):\n");
fflush(stdin);
boo=CreateBiTree(T);
if(!boo){
//printf("\n构建成功!!\n");
while(!boo){
printf("\n构建树为空树,请重新构建:");
printf("\n请输入树节点元素(请回车输入下一个数):\n");
boo=CreateBiTree(T);
}
}else{
printf("\n构建成功!!\n");
} OperateMenu();
scanf("%d",&k);
while(k){
switch(k){
case :break;
case :
printf("先序遍历结果为:\n");
boo=DLR(T);
if(boo)
printf("\n先序遍历成功!!\n");
else
printf("\n先序遍历失败!!\n");
break;
case :
printf("中序遍历结果为:\n");
boo=LDR(T);
if(boo)
printf("\n中序遍历成功!!\n");
else
printf("\n中序遍历失败!!\n");
break;
case :
printf("后序遍历结果为:\n");
boo=LRD(T);
if(boo)
printf("\n后序遍历成功!!\n");
else
printf("\n后序遍历失败!!\n");
break;
case :
printf("其中是叶子节点的是:\n");
yezi(T);
break;
case :n=shendu(T);
printf("树的深度为:%d",n);
break; }
OperateMenu();
scanf("%d",&k);
} }
return OK;
}

c_数据结构_二叉树的遍历实现的更多相关文章

  1. 算法与数据结构(三) 二叉树的遍历及其线索化(Swift版)

    前面两篇博客介绍了线性表的顺序存储与链式存储以及对应的操作,并且还聊了栈与队列的相关内容.本篇博客我们就继续聊数据结构的相关东西,并且所涉及的相关Demo依然使用面向对象语言Swift来表示.本篇博客 ...

  2. 【PHP数据结构】二叉树的遍历及逻辑操作

    上篇文章我们讲了许多理论方面的知识,虽说很枯燥,但那些都是我们今天学习的前提,一会看代码的时候你就会发现这些理论知识是多么地重要了.首先,我们还是要说明一下,我们学习的主要内容是二叉树,因为二叉树是最 ...

  3. 【数据结构】二叉树的遍历(前、中、后序及层次遍历)及leetcode107题python实现

    文章目录 二叉树及遍历 二叉树概念 二叉树的遍历及python实现 二叉树的遍历 python实现 leetcode107题python实现 题目描述 python实现 二叉树及遍历 二叉树概念 二叉 ...

  4. C_数据结构_链式二叉树

    # include <stdio.h> # include <malloc.h> struct BTNode { int data; struct BTNode * pLchi ...

  5. c_数据结构_图_邻接表

    课程设计------邻接表 图的遍历实现课程设计:https://files.cnblogs.com/files/Vera-y/图的遍历_课程设计.zip #include<stdio.h> ...

  6. python数据结构之二叉树的遍历实例

    遍历方案   从二叉树的递归定义可知,一棵非空的二叉树由根结点及左.右子树这三个基本部分组成.因此,在任一给定结点上,可以按某种次序执行三个操作:   1).访问结点本身(N)   2).遍历该结点的 ...

  7. C_数据结构_链表的链式实现

    传统的链表不能实现数据和链表的分离,一旦数据改变则链表就不能用了,就要重新开发. 如上说示:外层是Teacher,里面小的是node. #ifndef _MYLINKLIST_H_ #define _ ...

  8. C_数据结构_循环队列

    # include <stdio.h> # include <malloc.h> typedef struct Queue { int * pBase; int front; ...

  9. C_数据结构_栈

    # include <stdio.h> # include <malloc.h> # include <stdlib.h> typedef struct Node ...

随机推荐

  1. 高效IO之Java IO体系(一)

    更多Android高级架构进阶视频学习请点击:https://space.bilibili.com/474380680 个人觉得可以用“字节流操作类和字符流操作类组成了Java IO体系”来高度概括J ...

  2. leetcode.数组.16最接近的三数之和-java

    1. 具体题目 给定一个包括 n 个整数的数组 nums 和 一个目标值 target.找出 nums 中的三个整数,使得它们的和与 target 最接近.返回这三个数的和.假定每组输入只存在唯一答案 ...

  3. 二、springcloud微服务测试环境搭建

    版本说明: springcloud:Greenwich.SR3 springboot:2.1.8 1.构建步骤 1.1.microservicecloud整体父工程Project 新建父工程micro ...

  4. 关于memset赋值无穷大无穷小

    memset(a,,sizeof(a)); 即得到无穷大. memset(a,,sizeof(a)); 即得到无穷小,与上述的值互为相反数. memset(a,,sizeof(a)); 即近似为第一个 ...

  5. 精选 Dubbo RPC 面试题,比较全面,含答案

    精选 Dubbo RPC 面试题,比较全面,含答案 hu1991die 搜云库技术团队 搜云库技术团队 微信号 souyunku 功能介绍 专注于分享最有价值的互联网技术干货文章,内容覆盖,Java后 ...

  6. 《提高c++性能的编程技术》读书笔记

    一个程序的执行效率是取决于改程序翻译成汇编语言之后的执行的机器指令的条数.而每一个机器指令的执行的周期是一定的.C语言和C++都是高于汇编语言的高级语言,其中,C语言源代码与其相应的机器指不是完全同一 ...

  7. C# Func和匿名方法 简单使用

    今天敲代码遇见一个问题,解决中用到了C#的Func和匿名方法,发现挺好用的 定义一个这样的方法可以避免重复写try catch 这里用到了Func<int,string> ,它其实就是一个 ...

  8. vue在v-for循环中绑定v-model

    原始示例 <div v-for="item in items"> <input type="text" v-model="'good ...

  9. delphi 单元 MSHTML 之Ihtmldocument2

    delphi : Ihtmldocument2接口的利用 MSHTML是微软公司的一个COM组件,该组件封装了HTML语言中的所有元素及其属性,穿越其供给的规范接口,能够访问指定网页的所有元素. MS ...

  10. NX二次开发-UFUN删除链表函数UF_MODL_delete_list

    NX9+VS2012 #include <uf.h> #include <uf_modl.h> #include <uf_obj.h> #include <u ...