#include<stdio.h>
#include<stdlib.h>
#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0
#define OVERFLOW -1 #define STACK_INIT_SIZE 100
#define STACKINCREMENT 10 typedef int Status;
typedef char ElemType;
typedef struct BTNode{//定义树节点结构体
ElemType data;
struct BTNode *l;
struct BTNode *r;
}BTNode,*BinTree;
typedef BinTree SElemType;
typedef struct{//非递归遍历要使用的栈操作定义
SElemType *base;
SElemType *top;
int stacksize;//当前的栈空间容量
}SqStack;
//定义二叉树的基本操作
BinTree CreateBinTree(BinTree T);//创建二叉树并且返回一个指针
Status Visit(ElemType e);
Status Depth(BinTree T);
Status PreOrderRecursionTraverse(BinTree T,Status(*Visit)(ElemType e));
Status LevelOrderRecursionTraverse(BinTree T,Status(*Visit)(ElemType e));
//定义栈的基本操作
Status InitStack(SqStack *S);
Status Destroy(SqStack *S);
Status StackEmpty(SqStack S);
Status GetTop(SqStack *s,SElemType *e);
Status Pop(SqStack *S,SElemType *e);
Status Push(SqStack *S,SElemType e);
Status StackTraverse(const SqStack *S);//常量? Status PreOrderNoneRecursionTraverse(BinTree T,Status(*Visit)(ElemType e));//非递归先序遍历 int main(){
//int depth;
BinTree Tree=NULL;
Status(*Visit)(ElemType e)=Visit;//使用函数指针,用指针调用函数
printf("请按先序遍历输入二叉树元素(空节点为=):\n");
Tree=CreateBinTree(Tree);
printf("\n先序遍历:\n");
PreOrderRecursionTraverse(Tree,Visit);
printf("\n层序遍历:\n");
LevelOrderRecursionTraverse(Tree,Visit);
}
BinTree CreateBinTree(BinTree T){
char ch;
scanf("%c",&ch);
if(ch=='='){
T=NULL;
}else{
if(!(T=(BTNode *)malloc(sizeof(BTNode)))){
exit(OVERFLOW);
}
T->data=ch;
T->l=CreateBinTree(T->l);
T->r=CreateBinTree(T->r);
}
return T;//返回的T为最后一个结点
}
Status Visit(ElemType e){
if(e=='\0'){
return ERROR;
}else{
printf("%c",e);
}
return OK;
}
Status PreOrderRecursionTraverse(BinTree T,Status(*Visit)(ElemType e))
{
if(T){//判空
if(!Visit(T->data)){//访问不成功,visit返回的是error
return ERROR;
}
PreOrderRecursionTraverse(T->l,Visit);
PreOrderRecursionTraverse(T->r,Visit);
}
return OK;
}
//层遍历
Status LevelOrderRecursionTraverse(BinTree T,Status(*Visit)(ElemType e))
{
if(T){
int front=-;//每一次循环中表示从左到右的父节点的增加
int rear=-;//每一次循环当中用来表示front下一层该父节点左右子节点的变化增加
BTNode *Q[];//用来存储呢每一层从左到右的每一个树节点
Q[++rear]=T;
printf("根节点的数据:%d ",T->data);
while(front!=rear){
BTNode *p;
if(!(p=(BTNode *)malloc(sizeof(BTNode)))){
exit(OVERFLOW);
}
p=Q[++front];
if(p->l){
Q[++rear]=p->l;
printf("节点%d 的数据:%d",rear,p->l->data);
}
if(p->r){
Q[++rear]=p->r;
printf("节点%d 的数据:%d",rear,p->r->data);
}
} } }
/*
Status Depth(BinTree T){
int a,b;
if(!T){
return ERROR;
}else{
a=Depth(T->l)+1;
b=Depth(T->r)+1;
return a>b?a:b;
}
}
Status PreOrderNoneRecursionTraverse(BinTree T,Status(*Visit)(ElemType e)){
SqStack S;
SElemType p;
InitStack(&S);
Push(&S,T);//将T入栈作为第一个操作结点
while(S.base!=S.top){//栈不为空就一直循环,从上到下从左到右的取出
Pop(&S,&p);
if(!Visit(p->data)){//判断是否访问成功
return ERROR;
}
if(p->l){
Push(&S,p->r);//右结点先入栈为了后出栈
}
if(p->r){
Push(&S,p->l);
}
}
DestroyStack(&S);//释放栈
return OK;
}*/

c语言描述的二叉树的基本操作(层序遍历,递归,非递归遍历)的更多相关文章

  1. 【数据结构】——搜索二叉树的插入,查找和删除(递归&非递归)

    一.搜索二叉树的插入,查找,删除 简单说说搜索二叉树概念: 二叉搜索树又称二叉排序树,它或者是一棵空树,或者是具有以下性质的二叉树 若它的左子树不为空,则左子树上所有节点的值都小于根节点的值 若它的右 ...

  2. c/c++二叉树的创建与遍历(非递归遍历左右中,破坏树结构)

    二叉树的创建与遍历(非递归遍历左右中,破坏树结构) 创建 二叉树的递归3种遍历方式: 1,先中心,再左树,再右树 2,先左树,再中心,再右树 3,先左树,再右树,再中心 二叉树的非递归4种遍历方式: ...

  3. 二叉树的递归,非递归遍历(C++)

    二叉树是一种非常重要的数据结构,很多其它数据结构都是基于二叉树的基础演变而来的.对于二叉树,有前序.中序以及后序三种遍历方法.因为树的定义本身就是递归定义,因此采用递归的方法去实现树的三种遍历不仅容易 ...

  4. 递归/非递归----python深度遍历二叉树(前序遍历,中序遍历,后序遍历)

    递归代码:递归实现很简单 '二叉树结点类' class TreeNode: def __init__(self, x): self.val = x self.left = None self.righ ...

  5. c++实现二叉树层序、前序创建二叉树,递归非递归实现二叉树遍历

    #include <iostream> #include <cstdio> #include <stdio.h> #include <string> # ...

  6. 二叉树的先序、中序以及后序遍历(递归 && 非递归)

    树节点定义: class TreeNode { int val; TreeNode left; TreeNode right; TreeNode(int x) { val = x; } } 递归建立二 ...

  7. 二叉树——遍历篇(递归/非递归,C++)

    二叉树--遍历篇 二叉树很多算法题都与其遍历相关,笔者经过大量学习.思考,整理总结写下二叉树的遍历篇,涵盖递归和非递归实现. 1.二叉树数据结构及访问函数 #include <stdio.h&g ...

  8. C++版 - LeetCode 144. Binary Tree Preorder Traversal (二叉树先根序遍历,非递归)

    144. Binary Tree Preorder Traversal Difficulty: Medium Given a binary tree, return the preorder trav ...

  9. java数据结构之二叉树遍历的非递归实现

    算法概述递归算法简洁明了.可读性好,但与非递归算法相比要消耗更多的时间和存储空间.为提高效率,我们可采用一种非递归的二叉树遍历算法.非递归的实现要借助栈来实现,因为堆栈的先进后出的结构和递归很相似.对 ...

随机推荐

  1. QQ音乐:React v16 新特性实践

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由QQ音乐技术团队发表于云+社区专栏 自从去年9月份 React 团队发布了 v16.0 版本开始,到18年3月刚发布的 v16.3 版 ...

  2. JS之this那些事

    一直以来,对this的讨论都是热门话题.有人说掌握了this就掌握了JavaScript的80%,说法有点夸张,但可见this的重要性.至今记录了很多关于this的零碎笔记,今天就来个小结. 本人看过 ...

  3. HTML5 总结 (1)

    HTML5新表单 1.Input 新类型:email  url  tel number range date color date week month....... <html> < ...

  4. 02.ArrayList和HashTable

    ArrayList集合 数组的缺点: (1).数组只能存储相同类型的数据. (2).数组的长度要在定义时确定. 集合的好处: (1).集合可以存储多种不同类型的数据. (2).集合的长度是可以任意改变 ...

  5. 数据库中char、varchar、varchar2、nvarchar之间的关系

    符串“abc",对于CHAR (20),表示你存储的字符将占20个字节(包括17个空字符),而同样的VARCHAR2 (20)则只占用3个字节的长度,20只是最大值,当你存储的字符小于20时 ...

  6. C# tcp udp 串口 通信

    简单的实现tcp同步和异步,udp,串口通信 static List<TcpClientState> clientArray = new List<TcpClientState> ...

  7. CRM——起步

    一.CRM简介 crm 客户关系管理软件 ( Customer Relationship Management ). 二.CRM起步 1.设计表结构和数据库迁移 from django.db impo ...

  8. 类数组arguments

    var isArray = function(){ return arguments; } isArray(1,2,3); // 返回[1,2,3] isArray.call(null,1,2,3); ...

  9. 解决C#调试ArcMap断点不能停的问题

    问题出在ArcMap bin\ArcMap.exe.config 默认是不支持NET4.0 <startup> <!--<supportedRuntime version=&q ...

  10. Android 环信聊天头像昵称显示解决方案

    从消息扩展中获取昵称和头像 昵称和头像的获取:把用户基本的昵称和头像的URL放到消息的扩展中,通过消息传递给接收方,当收到一条消息时,则能通过消息的扩展得到发送者的昵称和头像URL,然后保存到本地数据 ...