二叉树的遍历:
(递归算法)
1.先序遍历(根左右) void PreOrder(BiTree T) { if (T != NULL) { visit(T); PreOrder(T->lchild); PreOrder(T->rchild); } } 2.中序遍历(左根右) void InOrder(BiTree T) { if (T != NULL) { InOrder(T->lchild); visit(T); InOrder(T->rchild); } } 3.后序遍历(左右根) void PostOrder(BiTree T) { if (T != NULL) { PostOrder(T->lchild); PostOrder(T->rchild); visit(T); }
(非递归算法)
1.先序遍历(根左右) void PreOrder(BiTreeNode T) { initStack(stack); if (T != NULL) { push(stack, T); } while (!isEmpty(stack)) { BiTreeNode *node = pop(stack); visit(node); if (node->rchild != NULL) { push(&stack, node->rchild); } if (node->lchild != NULL) { push(stack, node->lchild); } } } 2.中序遍历(左根右) void InOrder(BiTreeNode T) { initStack(stack); BiTreeNode *current = T; while (current != NULL || !isEmpty(stack)) { while (current != NULL) { push(stack, current); current = current->lchild; } current = pop(stack); visit(current); current = current->rchild; } } 3.后序遍历(左右根) void PostOrderNonRecursive(BiTreeNode T) { initStack(stack1); initStack(stack2); if (T != NULL) { push(stack1, T); } while (!isEmpty(stack1)) { BiTreeNode *node = pop(stack1); push(stack2, node); if (node->lchild != NULL) { push(stack1, node->lchild); } if (node->rchild != NULL) { push(stack1, node->rchild); } } while (!isEmpty(stack2)) { BiTreeNode *node = pop(stack2); visit(node); } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?