Emery_fly 2017-05-19 07:39 采纳率: 50%
浏览 1166
已结题

数据结构问题,二叉树非递归先序遍历,按下图步骤用C++方式编写

int PreOrder(BiTree pTree)
{
BiTNode* Stack[MAX_STACK_SIZE]; // 栈。用于存储右孩子
int top = 0; // 栈顶。0 表示空栈
BiTNode* pNode; // 二叉树节点指针
pNode=pTree;
if(!pTree)
{
cout<<"空树!\n";
return 0;
}
do
{
while(pNode!=NULL)
{
g_string[top]=pNode->data;
Stack[top]=pNode->rchild;
pNode=pNode->lchild;
top++;
}
if(!Stack)
{
g_string[top]=Stack[top=top-2]->data;
Stack[top--]=pNode->rchild;
top++;
}
else break;
}while(1);
if( g_string[top]=='\0')
cout<<g_string<<endl;
system("pause");
return 0;
}
求大神,实在不晓得怎么做
图片说明

  • 写回答

2条回答 默认 最新

  • shen_wei 2017-05-19 07:55
    关注
    评论

报告相同问题?

悬赏问题

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