yzlee_1991 2015-01-15 15:36 采纳率: 0%
浏览 1851

有关后序非递归遍历二叉树的问题

void show_LRD(tree LRD)
{
//后序非递归遍历二叉树
int otherstack[max];//辅助栈,用于检测出栈时是否已经遍历右子树
int *othertop,*otherbottom;
tree temp;
othertop=otherbottom=otherstack;
while(LRD||!emptystack())
{
while(LRD)
{
while(LRD)
{

inputstack(LRD);
*othertop++=0;
LRD=LRD->lchild;
}
LRD=gettopstack();
LRD=LRD->rchild;
*(othertop-1)=1;
}
while(
(othertop-1)==1)
{
popstack(&temp);
printf("%c",temp.date);
othertop--;
}
*(othertop-1)=1;
LRD=gettopstack();
LRD=LRD->rchild;
}
}
这是我写的后序非递归遍历二叉树。我用这个与后序递归遍历二叉树一起输出,结果是一样的,可是输出后程序立马就崩溃了。到底问题出在哪,实在想不明。

  • 写回答

3条回答

  • devmiao 2015-01-15 15:53
    关注

    使用一个堆栈记录下之前遍历的节点。

    评论

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器