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;
}
求大神,实在不晓得怎么做
数据结构问题,二叉树非递归先序遍历,按下图步骤用C++方式编写
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
悬赏问题
- ¥15 素材场景中光线烘焙后灯光失效
- ¥15 请教一下各位,为什么我这个没有实现模拟点击
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 ubuntu子系统密码忘记
- ¥15 保护模式-系统加载-段寄存器