c语言描述的二叉树的基本操作(层序遍历,递归,非递归遍历)
#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语言描述的二叉树的基本操作(层序遍历,递归,非递归遍历)的更多相关文章
- 【数据结构】——搜索二叉树的插入,查找和删除(递归&非递归)
一.搜索二叉树的插入,查找,删除 简单说说搜索二叉树概念: 二叉搜索树又称二叉排序树,它或者是一棵空树,或者是具有以下性质的二叉树 若它的左子树不为空,则左子树上所有节点的值都小于根节点的值 若它的右 ...
- c/c++二叉树的创建与遍历(非递归遍历左右中,破坏树结构)
二叉树的创建与遍历(非递归遍历左右中,破坏树结构) 创建 二叉树的递归3种遍历方式: 1,先中心,再左树,再右树 2,先左树,再中心,再右树 3,先左树,再右树,再中心 二叉树的非递归4种遍历方式: ...
- 二叉树的递归,非递归遍历(C++)
二叉树是一种非常重要的数据结构,很多其它数据结构都是基于二叉树的基础演变而来的.对于二叉树,有前序.中序以及后序三种遍历方法.因为树的定义本身就是递归定义,因此采用递归的方法去实现树的三种遍历不仅容易 ...
- 递归/非递归----python深度遍历二叉树(前序遍历,中序遍历,后序遍历)
递归代码:递归实现很简单 '二叉树结点类' class TreeNode: def __init__(self, x): self.val = x self.left = None self.righ ...
- c++实现二叉树层序、前序创建二叉树,递归非递归实现二叉树遍历
#include <iostream> #include <cstdio> #include <stdio.h> #include <string> # ...
- 二叉树的先序、中序以及后序遍历(递归 && 非递归)
树节点定义: class TreeNode { int val; TreeNode left; TreeNode right; TreeNode(int x) { val = x; } } 递归建立二 ...
- 二叉树——遍历篇(递归/非递归,C++)
二叉树--遍历篇 二叉树很多算法题都与其遍历相关,笔者经过大量学习.思考,整理总结写下二叉树的遍历篇,涵盖递归和非递归实现. 1.二叉树数据结构及访问函数 #include <stdio.h&g ...
- C++版 - LeetCode 144. Binary Tree Preorder Traversal (二叉树先根序遍历,非递归)
144. Binary Tree Preorder Traversal Difficulty: Medium Given a binary tree, return the preorder trav ...
- java数据结构之二叉树遍历的非递归实现
算法概述递归算法简洁明了.可读性好,但与非递归算法相比要消耗更多的时间和存储空间.为提高效率,我们可采用一种非递归的二叉树遍历算法.非递归的实现要借助栈来实现,因为堆栈的先进后出的结构和递归很相似.对 ...
随机推荐
- mysql存储过程嵌套循环并分页处理数据
业务背景:公司存证产品升级,随着数据量的增加,存证产品线按业务分表,导致以往的存证关联数据需要做数据同步更新.版本发布前,通过当前存储过程解决数据升级问题. ##创建存证文档关联情况下更新所用存储过程 ...
- 文档生成工具Sandcastle Help File Builder
Sandcastle Help File Builder http://shfb.codeplex.com/
- DJango小总结一
views.py def func(request): # 包含所有的请求数据 ... ...
- java面试知识
Java基础部分 https://www.cnblogs.com/xiaolovewei/p/9571770.html MySQL部分 https://www.cnblogs.com/xiaolove ...
- C# 矩阵运算和一些基本的几何运算
以前工作中写的,这里备个份,有可能用到 基本的矩阵运算类,测试20阶以内应该没啥问题,超过20阶不好使... /// <summary> /// 矩阵 异常 512索引 1024无解 20 ...
- POJO对象
POJO(Plain Old Java Objects)简单的Java对象,实际就是普通JavaBeans,是为了避免和EJB混淆所创造的简称. 使用POJO名称是为了避免和 EJB混淆起来, 而且简 ...
- Visual Studio Code 设置中文语言版本
设置方法有两种: 方法一1.选择扩展 搜索“Language”,在下列选项选择 Chinese (Simplified) Language Pack for Visual Studio Code安装, ...
- 为mongodb添加账号
进入切换到某一个数据库,我这里是位每个模块分配一个DataBase use 0 执行添加账号命令 db.createUser( { user: "*****", pwd: &quo ...
- Regular Expression 正则表达式
1. "^"表示以什么字符开始,"$"表示以什么字符结束: 2. \w表示字符类,包括大小写字母和数字: 3. “+”表示一个或多个,"*" ...
- linux配置IP
1.配置ip的几种方式: 1.使用ifconfig命令(临时配置,重启后失效) 2.使用setup工具(RedHat专有的,不过经本人测试,虚拟机装了centos,也有setup,也可以进行配置, ...