• 手机版

    扫码体验手机版

  • 微信公众号

    扫码关注公众号

国内首家协议开发

软芯音视解码保护平台

在线
客服

发布
需求

在线
聊天

天盟
APP

天盟APP下载

关注
微信

微信扫一扫访问
顶部

c语言用栈实现二叉树的先序非递归遍历,程序运行一半就停止了怎么改?

#include
#include
#define MaxSize 30
typedef char DataType;
typedef struct Node
{
   DataType data;
   struct Node *Lchild;
   struct Node *Rchild;
} BiTNode, *BiTree;

typedef struct Stacknode
{
   char data[MaxSize];
   int top;
}SeqStack;

SeqStack *InitStack()
{
    SeqStack *s;
    s=malloc(sizeof(SeqStack));
    s->top=-1;
    return s;
}

int IsEmpty(SeqStack *s)
{
    if(s->top==-1) return 1;
    else return 0;
}

int Push(SeqStack *s, char x)
{
   if(s->top==MaxSize-1)    return 0;
   else{
       s->top++;
       s->data[s->top]=x;
       return 1;
   }
}

int Pop(SeqStack *s,char *x)
{
    if(IsEmpty(s))  return 0;
    else {
        *x=s->data[s->top];
        s->top--; return 1;
    }
}

void CreateBiTree(BiTree *root)
{
   char ch;
   ch=getchar();
   if(ch=='#')  
   *root=NULL;
   else
   {
    *root=(BiTree)malloc(sizeof(BiTNode));
    (*root)->data=ch;
    CreateBiTree(&((*root)->Lchild));
    CreateBiTree(&((*root)->Rchild));
   }
}

void PreOrder(BiTree root)
{
     SeqStack *s;
     BiTree p;
     InitStack(s);
     p=root;
     while(p!=NULL||!IsEmpty(s))
     {
         while (p!=NULL)
         {
             printf("%c",p->data);
             Push(s,p);
             p=p->Lchild;
         }
         if(!IsEmpty(s))
         {
             Pop(s,&p);
             p=p->Rchild;
         }
     }
}


int main()
{
     BiTree root;
     CreateBiTree(root);
     PreOrder(root);
}

免责声明:本内容仅代表回答会员见解不代表天盟观点,请谨慎对待。

版权声明:作者保留权利,不代表天盟立场。

使用道具 举报

发新帖

发布任务需求已有1031167位用户正在使用天盟网服务

发布分类: *
任务预算: *
需求内容: *
手机号码: *
任务商家报价为
  • 预算价 :
  • 成交价 :
  • 完工期 :
  • 质保期 :

* 最终任务项目以服务商报价、双方协商为准!