1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > C语言完整代码实现:二叉树的先序遍历 中序遍历 后序遍历

C语言完整代码实现:二叉树的先序遍历 中序遍历 后序遍历

时间:2021-05-06 19:42:19

相关推荐

C语言完整代码实现:二叉树的先序遍历 中序遍历 后序遍历

一、先序遍历原理

先序遍历就是:根、左、右,也就是先遍历根结点再遍历左结点最后再遍历右结点,注意:如果遍历到的结点不是叶子结点的话需要对该结点进行拆分,比如这棵二叉树:

先遍历A,然后是B,然后再是C,但是由于B并不是叶子结点,他本身又是一棵子树的根结点,所以B可以拆分成B、D、E(根、左、右),同理因为C本身又是一棵子树的根结点根据先序遍历的原则C也可以拆分为C、F(根、左、右),然后再组合在一起便是A、B、D、E、C、F,此时D还不是叶子结点,同理再将D进行拆分为D、G(根左右),最后得到A、B、D、G、E、C、F。如下图所示

二、代码实现

通过上面的分析我们可以通过递归来实现树的遍历

1、先序遍历

void preOrder(BiTree T){if(T != NULL){visit(T);//先访问根节点preOrder(T->lchild);//再访问左结点preOrder(T->rchild);//最后访问右结点}return;}

2、中序遍历

void midOrder(BiTree T){if(T != NULL){midOrder(T->lchild);//先访问左结点visit(T);//再访问根结点midOrder(T->rchild);//最后访问右结点}return;}

3、后序遍历

void lastOrder(BiTree T){if(T != NULL){lastOrder(T->lchild);//先访问左结点lastOrder(T->rchild);//再访问右结点visit(T);//最后访问根节点}return;}

其中visit函数就是打印访问到的结点,xxxOrder函数就是一个递归函数,如果T已经是叶子结点了,那么就会返回,如果T是分支结点,也就是说还有左孩子或右孩子的话那么就访问对应的左孩子或右孩子,直到为叶子结点再返回,可以理解为上面讲的拆分(剥开)的原理,其实也就是递归的原理。

4、完整代码实现

#include <stdio.h>#include <stdlib.h>typedef struct BiTNode{char data;struct BiTNode *lchild, *rchild;}BiTNode,*BiTree;//初始化根节点BiTree init_Tree(BiTree T){//创建根节点,让指针T指向根节点T = (BiTree)malloc(sizeof(struct BiTNode));T->data = 'A';T->lchild = NULL;T->rchild = NULL;return T;}BiTree insert_Tree_left(BiTree Tree,char ch){BiTree p = (BiTree) malloc(sizeof(struct BiTNode));p->lchild = NULL;p->rchild = NULL;p->data = ch;Tree->lchild = p;return p;}BiTree insert_Tree_right(BiTree Tree,char ch){BiTree p = (BiTree) malloc(sizeof(struct BiTNode));p->lchild = NULL;p->rchild = NULL;p->data = ch;Tree->rchild = p;return p;}//访问对应的结点的值void visit(BiTree tree){printf("%c ",tree->data);return;}//树的先序遍历void preOrder(BiTree T){if(T != NULL){visit(T);//先访问根节点preOrder(T->lchild);//再访问左结点preOrder(T->rchild);//最后访问右结点}return;}//中序遍历void midOrder(BiTree T){if(T != NULL){midOrder(T->lchild);//先访问左结点visit(T);//再访问根结点midOrder(T->rchild);//最后访问右结点}return;}void lastOrder(BiTree T){if(T != NULL){lastOrder(T->lchild);//先访问左结点lastOrder(T->rchild);//再访问右结点visit(T);//最后访问根节点}return;}int main() {BiTree T = NULL;T = init_Tree(T);BiTree B = insert_Tree_left(T,'B');BiTree C = insert_Tree_right(T,'C');BiTree D = insert_Tree_left(B,'D');BiTree E = insert_Tree_right(B,'E');insert_Tree_right(D,'G');insert_Tree_left(C,'F');printf("先序遍历:");preOrder(T);printf("\n");printf("中序遍历:");midOrder(T);printf("\n");printf("后序遍历:");lastOrder(T);return 0;}

5、运行结果

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。