后序遍历非递归算法 c/c++
//非递归算法后序遍历二叉树 void PostOrder1(BTNode *b) { BTNode *St[MaxSize];BTNode *p;int top = -1; //建立栈并初始化 BTNode *r; //保存前一个访问的结点 bool flag; p = b; //p指向根节点 do { while(p != NULL) //读取当前结点及其所有左下结点 { St[++top] = p; p = p->lchild; } r = NULL; //每一次循环开始,初始化r flag = true; //表示当前处理的是栈顶结点 while(top != -1 && flag) { p = St[top]; //取栈顶元素 if(p->rchild == r) //当前栈顶元素右孩子已经被访问过或者为空,说明右子树遍历完,然后访问当前结点并出栈 { cout<<p->data; r = p; top--; } else //转向右子树 { p = p->rchild; flag = false; //表似乎当前处理的是右子树 } } }while(top != -1); }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统