c语言在黑白窗口显示二叉树,c语言二叉树基本操作

编译器为vs2013

#include "stdafx.h"

#include

#include

#define OVERFLOW -1

typedef char BElemType;

typedef int Status;

typedef struct BiTree{

BElemType data;

struct BiTree *lchild,*rchild;

}BitNode,*BinTree;

//函数声明

void CreatTree(BinTree &T);                      //构建二叉树并赋值

void PreOrderTaverse(BinTree T);                 //先序遍历二叉树并输出

void InOrderTaverse(BinTree T);                  //中序遍历二叉树并输出

void PostOrderTaverse(BinTree T);                //后序遍历二叉树并输出

Status DepthTree(BinTree T);                     //返回树的深度

Status LeafNode(BinTree T, int &leaves);         //返回叶子结点个数

Status TreeNode(BinTree T, int &node);           //返回节点总数

int main()

{

int h, leaves=0, node=0;

BinTree T;

CreatTree(T);

PreOrderTaverse(T);

printf("\n");

InOrderTaverse(T);

printf("\n");

PostOrderTaverse(T);

printf("\n");

h=DepthTree(T);

leaves=LeafNode(T,leaves);

node = TreeNode(T,node);

printf("树的高度为%d\n叶子节点数为%d\n节点总数为%d\n", h, leaves, node);

}

//构建二叉树并赋值

void CreatTree(BinTree &T)

{

BElemType ch;

scanf_s("%c", &ch);

if (ch== ' ')

T = NULL;

else

{

if (!(T = (BinTree)malloc(sizeof(BitNode))))

exit(OVERFLOW);

T->data = ch;

CreatTree(T->lchild);

CreatTree(T->rchild);

}

}

//先序遍历二叉树并输出

void PreOrderTaverse(BinTree T)

{

if (T)

{

printf("%c ", T->data);

PreOrderTaverse(T->lchild);

PreOrderTaverse(T->rchild);

}

}

//中序遍历二叉树并输出

void InOrderTaverse(BinTree T)

{

if (T)

{

InOrderTaverse(T->lchild);

printf("%c ", T->data);

InOrderTaverse(T->rchild);

}

}

//后序遍历二叉树并输出

void PostOrderTaverse(BinTree T)

{

if (T)

{

PostOrderTaverse(T->lchild);

PostOrderTaverse(T->rchild);

printf("%c ", T->data);

}

}

//返回树的深度

Status DepthTree(BinTree T)

{

int dl,dr,deep;

if (!T)

deep = 0;

else if ((T->lchild == NULL)&&(T->rchild == NULL))

deep = 1;

else

{

dl=DepthTree(T->lchild);

dr=DepthTree(T->rchild);

deep = 1 + (dl > dr ? dl : dr);

}

return deep;

}

//返回叶子结点个数

Status LeafNode(BinTree T,int &leaves)

{

if (T)

{

if ((T->lchild == NULL) && (T->rchild == NULL))

leaves++;

LeafNode(T->lchild, leaves);

LeafNode(T->rchild, leaves);

}

return leaves;

}

//返回节点总数

Status TreeNode(BinTree T,int &node)

{

if (T)

{

node++;

TreeNode(T->lchild, node);

TreeNode(T->rchild, node);

}

return node;

}

c++学习笔记—二叉树基本操作的实现

用c++语言实现的二叉树基本操作,包括二叉树的创建.二叉树的遍历(包括前序.中序.后序递归和非递归算法).求二叉树高度,计数叶子节点数.计数度为1的节点数等基本操作. IDE:vs2013 具体实现代 ...

C语言指针基本操作

C语言指针基本操作 指针  指针介绍 如果说C语言最有魅力的地方在哪,那么毋庸置疑,非指针莫属了. 众所周知,C语言中每个变量都有一个内存地址,可以通过&进行访问.指针是一个变量,它的值是一个 ...

C语言SQLite3基本操作Demo

/************************************************************************** * C语言SQLite3基本操作Demo * 声 ...

Hello world!(内含自己编写的C语言二叉树同学录)

修改:刷了一段时间的题,水平渐涨,发现同学录真的要做成市面可行的应用的话,应该按学号建立二叉平衡树,红黑树是一个可行的选择. 在同学的推荐下,来到博客园来找志同道合的人交流代码.3个月后参加蓝桥杯 ...

二叉树基本操作C++

#include #include #include #include ...

C语言二叉树的建立与遍历

二叉树的建立和遍历都要用到递归,先暂时保存一下代码,其中主要是理解递归的思想,其它的就都好理解了.这里是三种遍历方式,其实理解一种,其它的几个就都理解了,就是打印出来的顺序不一样而已.建立和遍历的方式 ...

[数据结构]C语言二叉树的实现

树和图是数据结构中比较麻烦的东西,里面涉及的概念比较多,也最有用, 就比如一般树广泛应用于人工智能的博弈上,而基于图的广度优先和深度优先搜索也广泛应用于人工智能寻路上面 首先我们要把树进行分类: &g ...

Go语言二叉树定义及遍历算法实现

// binary_tree 二叉树 package Algorithm import ( "reflect" ) // 二叉树定义 type BinaryTree struct ...

C语言二叉树的创建、(先中后序)遍历以及存在的问题

#include #include #define True 1 #define False 0 typedef char TElemTy ...

随机推荐

类:String,Math,DateTime,Random随机数,异常保护

String类: 练习: Math类: Random随机数: DateTime类: 异常保护: 练习: 1. 2. 3.方法一: 方法二: 4.人机大战石头剪刀布 5. //请输入你想输入的数字 // ...

junit高级篇(参数化、打包测试)-实例代码

工程目录: 参数化测试,SquareTest.java: import static org.junit.Assert.*; import java.util.Arrays; import java. ...

SPOJ 370 Ones and zeros BFS + 同余剪枝

题意:给一些n,求出最小的只包含0,1的n的倍数 设两数a, b满足: a < b 并且a % n = b % n. 如果 ( a * 10^x + c ) % n = z , 根据同余定理,( ...

(转)sql 时间转换格式 convert(varchar(10),字段名,转换格式)

convert(varchar(10),字段名,转换格式) CONVERT(nvarchar(10),count_time,121) CONVERT为日期转换函数,一般就是在时间类型(datetime ...

hdu4293Groups

http://acm.hdu.edu.cn/showproblem.php?pid=4293 这题单拉出来写篇吧 确实不错的一题 将每个人说的话 转化一下 可以算出它处在哪个段中 题目就转换成了求不相 ...

hiberbate的工作原理

hibernate 简介:hibernate是一个开源框架,它是对象关联关系映射的框架,它对JDBC做了轻量级的封装,而我们java程序员可以使用面向对象的思想来操纵数据库.hibernate核心接口 ...

spring cloud 自定义ribbon客户端

一.自定义Ribbon客户端-[方式一]配置类 1.1.自定义负载规则 增加RibbonConfiguration.java配置类 public class RibbonConfiguration { ...

docker安装Zabbix

1. 先安装数据库mysqldocker run --name zabbix-mysql-server --hostname zabbix-mysql-server \-e MYSQL_ROOT_PA ...

算法笔记-PHP实现队列的操作

[队列]先进者先出,这就是典型的“队列”.         最基本的两个操作:入队enqueue(),放一个数据到队列尾部:出队dequeue(),从队列头部取一个元素.队列可以用数组或者链表实现,用 ...

wordpress学习五: 通过wordpress_xmlrpc的python包远程操作wordpress

wordpress提供了丰富的xmlrpc接口api来供我们远程操控wp的内容.伟大的开源社区有人就将这些api做了一下封装,提供了一个功能比较完整的python库,库的使用文档地址http://py ...

你可能感兴趣的:(c语言在黑白窗口显示二叉树)