<youcengcibianli>
- #include<stdio.h>
- #include<stdlib.h>
- #include<string.h>
- #define num 100
- #define OK 1
- #define ERROR 0
- #define OVERFLOW -1
- #define FALSE 0
- #define TRUE 1
- typedef int Status;
- typedef char DataType;
- typedef struct node
- {
- DataType data;
- struct node *lchild,*rchild;
- }BinTNode,*BinTree;
- typedef BinTNode* ElemType;
- #define QueueSize 100
- //循环队列的存储结构
- typedef struct
- {
- ElemType *base;
- int front,rear;
- }SeQueue;
- Status CreateBiTree(BinTree &bt)
- {//按照先序遍历次序递归建立二叉树。
- //ABC@@DE@G@@F@@
- char ch;
- scanf("%c",&ch);
- if(ch == '@') bt = NULL;
- else
- {
- bt = (BinTNode*)malloc(sizeof(BinTNode));
- bt->data = ch; //生成根结点
- CreateBiTree(bt->lchild); //构造左子树
- CreateBiTree(bt->rchild); //构造右子树
- }
- return OK;
- }
- Status Inorder(BinTree bt)
- {//二叉树中序遍历非递归算法
- BinTNode *stack[num]; //定义栈数组
- int top = ; //初始化栈
- stack[top] = bt;
- do
- {
- while(NULL!=stack[top])
- {//扫描根结点及其所有的左结点并入栈
- top = top+;
- stack[top] = stack[top-]->lchild;
- }
- top = top-; //退栈
- if(top>=) //判断栈是否为空
- {
- printf("%c",stack[top]->data); //访问结点
- stack[top] = stack[top]->rchild; //扫描右子树
- }
- }while(top>=);
- return OK;
- }
- void PostOrder(BinTree bt)
- {//二叉树后序遍历递归算法
- if(bt)
- {
- PostOrder(bt->lchild);
- PostOrder(bt->rchild);
- printf("%c",bt->data);
- }
- }
- int Size(BinTree bt)
- {//统计二叉树中所有结点的个数
- int num1,num2;
- if(bt==NULL)
- return ;
- else if(bt->lchild==NULL && bt->rchild==NULL)
- return ;
- else
- {
- num1 = Size(bt->lchild);
- num2 = Size(bt->rchild);
- return (num1+num2+);
- }
- }
- int LeafCount(BinTree bt)
- {//叶子结点总数为
- int LeafNum;
- if(bt==NULL)
- LeafNum = ;
- else if((bt->lchild==NULL) && (bt->rchild==NULL)) LeafNum = ;
- else LeafNum = LeafCount(bt->lchild)+LeafCount(bt->rchild);
- //叶子数为左右子树叶子数目之和
- return LeafNum;
- }
- int Depth(BinTree bt)
- {//统计二叉树深度
- int hl,hr,max;
- if(bt!=NULL)
- {
- hl = Depth(bt->lchild); //求左子树的深度
- hr = Depth(bt->rchild); //求右子树的深度
- max = hl>hr?hl:hr;
- return (max+); //返回树的深度
- }
- else
- return ;
- }
- void Exchange(BinTree bt)
- {//交换左右二叉树
- if(bt == NULL)
- return;
- BinTNode *temp;
- temp = bt->lchild;
- bt->lchild = bt->rchild;
- bt->rchild = temp;
- Exchange(bt->lchild);
- Exchange(bt->rchild);
- }
- //构造一个循环队列
- Status InitQueue(SeQueue &Q)
- {
- Q.base = (ElemType *)malloc(QueueSize *sizeof(ElemType));
- if(!Q.base) exit();
- Q.front = Q.rear = ;
- return OK;
- }
- //插入新的元素为队尾元素
- Status EnQueue(SeQueue &Q,ElemType e)
- {
- if((Q.rear+)%QueueSize==Q.front)
- {
- printf("Queue overflow");
- return ;
- }
- Q.base[Q.rear] = e;
- Q.rear = (Q.rear+)%QueueSize;
- return ;
- }
- //删除队头元素
- Status DeleteQ(SeQueue &Q,ElemType &e)
- {
- if(Q.front == Q.rear)
- {
- printf("Queue enpty");
- return ERROR;
- }
- e = Q.base[Q.front];
- Q.front = (Q.front+)%QueueSize;
- return OK;
- }
- //判空循环队列
- Status IsEmptyQ(SeQueue Q)
- {
- if(Q.front == Q.rear)
- return TRUE;
- else
- return FALSE;
- }
- //层次遍历二叉树
- void LevelOrderTraversal(BinTree bt)
- {
- SeQueue Q;
- ElemType e;
- //若是空树,则直接返回
- InitQueue(Q); //创建并初始化队列
- if(bt) EnQueue(Q,bt);
- while(!IsEmptyQ(Q))
- {
- DeleteQ(Q,e);
- printf("%4c",e->data);
- if(e->lchild) EnQueue(Q,e->lchild);
- if(e->rchild) EnQueue(Q,e->rchild);
- }
- }
- void main()
- {
- BinTree bt;
- int xz = ;
- int yz,sd;
- while(xz)
- {
- printf("二叉树的建立及其基本操作\n");
- printf("===========================\n");
- printf("1,建立二叉树的存储结构\n");
- printf("2,二叉树的基本操作\n");
- printf("3,交换二叉树的左右\n");
- printf("4,二叉树的层次遍历\n");
- printf("0退出系统\n");
- printf("==========================\n");
- printf("请选择:(0~4)\n");
- scanf("%d",&xz);
- getchar();
- switch(xz)
- {//输入:ABC@@DE@G@@F@@@输出:CBEGDFA
- case :
- printf("输入二叉树的先序序列结点值:\n");
- CreateBiTree(bt);
- printf("二叉树的链式存储结构建立完成\n");
- printf("\n");
- break;
- case :
- printf("该二叉树的后序遍历序列是:");
- PostOrder(bt);
- printf("\n"); //输出CGEFDBA
- printf("该二叉树的中序遍历序列是:");
- Inorder(bt);
- printf("\n"); //输出CBEGDFA
- printf("该二叉树的结点的个树是:%d\n",Size(bt));
- yz = LeafCount(bt);
- printf("叶子结点个数是:%d\n",yz);
- sd = Depth(bt);
- printf("该二叉树的深度是:%d\n",sd);
- printf("\n");
- break;
- case :
- Exchange(bt);
- printf("该二叉树已交换左右子树!\n");
- printf("\n");
- break;
- case :
- printf("该二叉树的层序遍历序列是:");
- LevelOrderTraversal(bt);
- printf("\n"); //输出ABCDEFG
- case :
- break;
- //default:printf("请输入正确的选项:(0~4):\n");
- // break;
- }
- }
- }
<youcengcibianli>的更多相关文章
- 简单物联网:外网访问内网路由器下树莓派Flask服务器
最近做一个小东西,大概过程就是想在教室,宿舍控制实验室的一些设备. 已经在树莓上搭了一个轻量的flask服务器,在实验室的路由器下,任何设备都是可以访问的:但是有一些限制条件,比如我想在宿舍控制我种花 ...
- 利用ssh反向代理以及autossh实现从外网连接内网服务器
前言 最近遇到这样一个问题,我在实验室架设了一台服务器,给师弟或者小伙伴练习Linux用,然后平时在实验室这边直接连接是没有问题的,都是内网嘛.但是回到宿舍问题出来了,使用校园网的童鞋还是能连接上,使 ...
- 外网访问内网Docker容器
外网访问内网Docker容器 本地安装了Docker容器,只能在局域网内访问,怎样从外网也能访问本地Docker容器? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Docker容器 ...
- 外网访问内网SpringBoot
外网访问内网SpringBoot 本地安装了SpringBoot,只能在局域网内访问,怎样从外网也能访问本地SpringBoot? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装Java 1 ...
- 外网访问内网Elasticsearch WEB
外网访问内网Elasticsearch WEB 本地安装了Elasticsearch,只能在局域网内访问其WEB,怎样从外网也能访问本地Elasticsearch? 本文将介绍具体的实现步骤. 1. ...
- 怎样从外网访问内网Rails
外网访问内网Rails 本地安装了Rails,只能在局域网内访问,怎样从外网也能访问本地Rails? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Rails 默认安装的Rails端口 ...
- 怎样从外网访问内网Memcached数据库
外网访问内网Memcached数据库 本地安装了Memcached数据库,只能在局域网内访问,怎样从外网也能访问本地Memcached数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装 ...
- 怎样从外网访问内网CouchDB数据库
外网访问内网CouchDB数据库 本地安装了CouchDB数据库,只能在局域网内访问,怎样从外网也能访问本地CouchDB数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Cou ...
- 怎样从外网访问内网DB2数据库
外网访问内网DB2数据库 本地安装了DB2数据库,只能在局域网内访问,怎样从外网也能访问本地DB2数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动DB2数据库 默认安装的DB2 ...
- 怎样从外网访问内网OpenLDAP数据库
外网访问内网OpenLDAP数据库 本地安装了OpenLDAP数据库,只能在局域网内访问,怎样从外网也能访问本地OpenLDAP数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动 ...
随机推荐
- Unity3D学习笔记(十九):UGUI、Image、Text、Button
UGUI:Unity官方最新,与NGUI同源 UI:User Interface(用户的操作界面),图片+文字 UGUI的组件: 1.创建UGUI组件时,会默认创建Canvas(画布)和EventSy ...
- java多线程编程模式
前言 区别于java设计模式,下面介绍的是在多线程场景下,如何设计出合理的思路. 不可变对象模式 场景 1. 对象的变化频率不高 每一次变化就是一次深拷贝,会影响cpu以及gc,如果频繁操作会影响性能 ...
- C指针 的一些练习
注:此篇是我使用指针敲的一些题目的集成,有一些代码是重复的(挠头).这样做的目的是进行前后的一些比较和收获一些心得(?). 关于上一次我上台的题目: 题目:输入十个整数,进行排序. 做法1:(传递指针 ...
- bnu 51636 Squared Permutation 线段树
Squared Permutation Time Limit: 6000ms Memory Limit: 262144KB 64-bit integer IO format: %lld Ja ...
- hdu 1325 Is It A Tree? 并查集
Is It A Tree? Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- python 打包成tar包
def make_targz(output_filename, source_dir): with tarfile.open(output_filename, "w:gz") as ...
- python 集合元素添加
#A new empty set color_set = set() color_set.add("Red") print(color_set) #Add multiple ite ...
- [ios]object-c math.h里的数学计算公式介绍
参考:http://blog.csdn.net/yuhuangc/article/details/7639117 头文件:<math.h> 1. 三角函数 double sin (dou ...
- 微信小程序 - 简述
1.小程序理解 基于微信的 免安装 MVVM 应用 编码使用 ES 6 一个页面基本组成:wxml wxss js ( html.css.js ) 2. 常见用法 ( 基本就是跟着例子走.. ) 设置 ...
- 30分钟了解如何使用Kafka
Kafka是当下对海量数据提供了最佳支持的MQ中间件,无论是高并发的处理,还是依托zookeeper的水平拓展都有不俗的特性.由于公司最近也在尝试如何将它应用到开发中以对业务更好的支撑,因此特地分享一 ...