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数据结构之二叉树遍历的非递归实现
算法概述递归算法简洁明了.可读性好,但与非递归算法相比要消耗更多的时间和存储空间.为提高效率,我们可采用一种非递归的二叉树遍历算法.非递归的实现要借助栈来实现,因为堆栈的先进后出的结构和递归很相似.对 ...
随机推荐
- 信鸽推送 C#版SDK
信鸽官方sdk没提供C#版的DEMO,考虑到应该有其他.NET的也会用到信鸽,下面是我在使用信鸽过程中写的demo.有什么不对的地方,欢迎各位大牛指导. 使用过程中主要是有2个问题: 1.参数组装,本 ...
- Web开发HTTP中URI和URL的情感纠葛
作者:郭无心链接:https://www.zhihu.com/question/21950864/answer/66779836来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明 ...
- oracle学习篇八:约束
----约束------- --1.主键约束--唯一标识,不能为空,通常用于ID--1>创建主键create table person(id varchar2(20) primary key,n ...
- Csharp:user WebControl Read Adobe PDF Files In Your Web Browser
namespace GeovinDu.PdfViewer { [DefaultProperty("FilePath")] [ToolboxData("<{0}:Sh ...
- 详解nodejs中使用socket的私聊和公聊的办法
详解nodejs中使用socket的私聊和公聊的办法 nodejs的应用中,关于socket应该是比较出彩的了,socket.io在github上有几万人的star,它的成功应该是不输于express ...
- C语言入门(一)环境搭建
1. 下载Code::Blocks(源文本编辑器) 2. 下载编译器MinGW(或者下载好自带编译器的codeblocks) http://jingyan.baidu.com/article/c843 ...
- Mirco F-measure and Macro F-measure
- 模拟Spring框架
BeanFactory package com.bjsxt.spring; public interface BeanFactory { public Object getBean(String na ...
- Cloud Foundry和微服务Meetup重磅来袭
CF 同学们: Cloud Foundry 2016 上海 Meetup 将在10月22日在上海港汇广场进行! 想要参会的小伙伴,请直戳 ~ 在过去的一年,CF 的技术有很多进展,微服务也是2016 ...
- Python装饰器AOP 不定长参数 鸭子类型 重载(三)
1 可变长参数与关键字参数 *args代表任意长度可变参数 **kwargs代表关键字参数 用*args和**kwargs只是为了方便并没有强制使用它们. 缺省参数即是调用该函数时,缺省参数的值若未被 ...