二叉树的遍历:
(递归算法)

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);
}
}
posted on   不爱美女爱辣条  阅读(9)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?



点击右上角即可分享
微信分享提示