数据结构C语言实现之二叉树与AVL树(绝对易于理解的非递归后序遍历与AVL树)


在这里插入图片描述
在这里插入图片描述
欢迎关注我,学习资料免费分享给你哦!还有其他超多学习资源,都是我自己学习过的,经过过滤之后的资源,免去你还在因为拥有大量资源不知如何入手的纠结,让你体系化学习。
在这里插入图片描述

二叉树结构的定义
typedef struct TNode *Position;
typedef Position BinTree;
struct TNode{
   
    ElementType Data;
    BinTree Left;
    BinTree Right;
};
二叉树的遍历(非递归方式)
#define STACK_SIZE 50
#define True 1
#define False 0
typedef struct Snode
{
   
  BinTree data[STACK_SIZE];
  int size;
};
typedef struct Snode *stack;
stack creatStack()
{
   
  stack s;
  s=(stack)malloc(sizeof(struct Snode));
  if(s==NULL)
  {
   
    return NULL;
  }
  s->size=-1;
  return s;
}
int isStackFull(stack s)
{
   
  return s->size==(STACK_SIZE-1);
}
int isStackEmpty(stack s)
{
   
  return s->size==-1;
}
void push(stack s,BinTree BT)
{
   
  if(isStackFull(s)==True)
  {
   
    return;
  }
  s->size++;
  s->data[s->size]=BT;
}
BinTree pop(stack s)
{
   
  if(isStackEmpty(s)==True)
  {
   
    return NULL;
  }
  return s->data[s->size--];
}
BinTree top(stack s)
{
   
  return s->data[s->size];
}
void destroyStack(stack s)
{
   
  free(s);
}
void InorderTraversal( BinTree BT )
{
   
  stack s;
  s=creatStack();
  if(s==NULL)
  {
   
    return;
  }
  while(!isStackEmpty(s)||(BT!=NULL))
  {
   
    while(BT!=NULL)
    {
   
      push(s,BT);
      BT=BT->Left;
    }
    BT=pop(s);
    printf(" %c",BT->Data);
    BT=BT->Right;
  }
  destroyStack(s);
}
//前序遍历
void PreorderTraversal( BinTree BT )
{
   
  stack s;
  s=creatStack();
  if(s==NULL)
  {
   
    return;
  }
  while(!isStackEmpty(s)||(BT!=NULL))
  {
   
    while(BT!=NULL)
    {
   
      push(s,BT);
      printf(" %c",BT->Data);
      BT=BT->Left;
    }
    BT=pop(s);
    BT=BT->Right;
  }
  destroyStack(s);
}
//后序遍历
void PostorderTraversal( BinTree BT )
{
   
  stack s;
  s=creatStack();
  if(s==NULL)
  {
   
    return;
  }
  if(BT==NULL)
  {
   
    return;
  }
  push(s,BT);
  push(s,BT);
  while(!isStackEmpty(s))
  {
   
    BT=pop(s);
    if(!isStackEmpty(s)&&BT==top(s))
    {
   
      if(
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值