//************************************************************************* // 【前序】遍历算法 //二叉树不空,先访问根结点,然后前序遍历左子树,再前序遍历右子树 //************************************************************************* void PreOrderTraverse(BiTree T) { if(T == NULL) /* 递归跳出条件*/ return; printf("%c", T ->data); /* 对结点进行操作(可替换成其它操作)*/ PreOrderTraverse(T ->lchild); /* 先序遍历左子树*/ PreOrderTraverse(T ->rchild); /* 先序遍历右字树*/ } //************************************************************************* // 【中序】遍历算法 //二叉树不空,从根结点开始(并非是先访问根结点),中序遍历根节点的左子树, //然后访问根结点,最后中序遍历该根结点的右子树 //************************************************************************* void InOrderTraverse(BiTree T) { if(T == NULL) /* 递归跳出条件*/ return; InOrderTraverse(T ->lchild); /* 中序遍历左子树*/ printf("%c", T ->data); /* 对结点进行操作(可替换成其它操作)*/ InOrderTraverse(T ->rchild); /* 中序遍历右字树*/ } //************************************************************************* // 【后序】遍历算法 //二叉树不空,从左到右先叶子后结点的方式遍历左右子树,最后遍历根结点 //************************************************************************* void PostOrderTraverse(BiTree T) { if(T == NULL) /* 递归跳出条件*/ return; PostOrderTraverse(T ->lchild); /* 后序遍历左子树*/ PostOrderTraverse(T ->rchild); /* 后序遍历右字树*/ printf("%c", T ->data); /* 对结点进行操作(可替换成其它操作)*/ }
本文介绍了二叉树的三种基本遍历算法:前序遍历、中序遍历及后序遍历,并提供了每种遍历方式的具体实现代码。通过这些算法可以有效地访问二叉树中的所有结点。
&spm=1001.2101.3001.5002&articleId=78559832&d=1&t=3&u=488d1f64e5ae474299af431e03693955)
544

被折叠的 条评论
为什么被折叠?



