wei xin_44706101 2019-11-27 15:57 采纳率: 100%

# 求大佬帮看看 二叉树后序遍历非递归问题

``````#include <stdio.h>
#include <stdlib.h>

typedef struct bnode
{
char data;
struct bnode *lchild;
struct bnode *rchild;
int top;
}bnode;

bnode stack[100];

void initstack(bnode * stack)
{
stack->top=-1;
}

void push(bnode*stack,bnode*p)
{

stack->top++;
stack[stack->top].data=p->data;
stack[stack->top].rchild=p->rchild;
stack[stack->top].lchild=p->lchild;

}

void pop(bnode*stack)
{
stack->top--;
}

int stackempty(bnode*stack)
{
if (stack->top==-1)
return 1;
return 0;
}

bnode * top(bnode*stack)
{
bnode* t=&stack[stack->top];
return t;
}

bnode * createtree()
{
char ch;
bnode *p;

ch=getchar();
if (ch=='#')
p=NULL;
else
{
p=(bnode*)malloc(sizeof(bnode));
p->data=ch;
p->lchild=createtree();
p->rchild=createtree();
}

return p;
}
{
bnode*pre=NULL;bnode*p;

initstack(stack);
push(stack,root);
while(!stackempty(stack))
{

p=top(stack);
if((!p->rchild&&!p->lchild)||(pre&&(pre==p->lchild||pre==p->rchild)))
{printf("%c",p->data);
pop(stack);
pre=p;
}
else
{if(p->rchild)
{
push(stack,p->rchild);}
if(p->lchild)
{
push(stack,p->lchild);}}

}}

void main()
{
bnode *root=createtree();
}
``````

• 写回答

#### 1条回答默认 最新

• threenewbee 2019-11-27 16:50
关注

逻辑不通
p=top(stack);
if((!p->rchild&&!p->lchild)||(pre&&(pre==p->lchild||pre==p->rchild)))
pre==p-lchild/rchild并不代表等于之前遍历的节点，因为堆栈是变化的。

``````#include <stdio.h>
#include <stdlib.h>

typedef struct bnode
{
char data;
struct bnode *lchild;
struct bnode *rchild;
}bnode;

bnode * stack[100];
int top;

void initstack()
{
top=-1;
}

void push(bnode*p)
{
top++;
stack[top]=p;
}

void pop()
{
top--;
}

int stackempty()
{
if (top==-1)
return 1;
return 0;
}

bnode * gettop()
{
bnode* t=stack[top];
return t;
}

bnode * createtree()
{
char ch;
bnode *p;

ch=getchar();
if (ch=='#')
p=NULL;
else
{
p=(bnode*)malloc(sizeof(bnode));
p->data=ch;
p->lchild=createtree();
p->rchild=createtree();
}

return p;
}
{
bnode*pre=NULL;bnode*p;

initstack();
push(root);
while(!stackempty())
{

p=gettop();
if((!p->rchild&&!p->lchild)||(pre&&(pre==p->lchild||pre==p->rchild)))
{printf("%c",p->data);
pop();
pre=p;
}
else
{if(p->rchild)
{
push(p->rchild);}
if(p->lchild)
{
push(p->lchild);}}

}}

void main()
{
bnode *root=createtree();
}
``````

ABD###CE##FG###
DBEGFCAPress any key to continue . . .

本回答被题主选为最佳回答 , 对您是否有帮助呢?
评论

#### 悬赏问题

• ¥20 请问这种量表怎么用spss量化分析（作为中介模型的因变量