这篇文章主要介绍了C中二叉树的建立和各种遍历实例代码,涉及树节点的定义,后序遍历,层序遍历,深度优先和广度优先等相关内容,具有一定借鉴价值,需要的朋友可以参考下
这里给一个样例树:
代码:
#include #include #include /* 二叉树的二叉链表结点结构定义 */ typedef struct BiTNode { char data; struct BiTNode *lchild,*rchild; }BiTNode,*BiTree; BiTree T=NULL; /* 先序遍历建立一个二叉树 */ void Create (BiTree *T) // 二级指针改变地址的地址 { char ch; scanf("%c",&ch); if(ch=='#') *T=NULL; else { *T=(BiTree)malloc(sizeof(BiTNode)); if(!*T) return ; else { (*T)->data=ch; Create(&(*T)->lchild); Create(&(*T)->rchild); } } } /* 二叉树的前序递归遍历算法 */ 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); } int main() { printf("请按先序遍历的结果输入树,例如:ABDH#K###E##CFI###G#J##\n"); Create(&T); printf("先序遍历的结果为:\n"); PreOrderTraverse(T); printf("\n"); printf("中序遍历的结果为:\n"); InOrderTraverse(T); printf("\n"); printf("后序遍历的结果为:\n"); PostOrderTraverse(T); printf("\n"); return 0; }
输出结果如下
PS:下面是一个用C++里面的取引用代替了二级指针
#include using namespace std; /* 二叉树的二叉链表结点结构定义 */ typedef struct BiTNode { char data; struct BiTNode *lchild,*rchild; }BiTNode,*BiTree; BiTree T=NULL; /* 先序遍历建立一个二叉树 */ void Create (BiTree &T) // C++取引用 { char ch; scanf("%c",&ch); if(ch=='#') T=NULL; else { T=(BiTree)malloc(sizeof(BiTNode)); if(!T) return ; else { T->data=ch; Create(T->lchild); Create(T->rchild); } } } /* 二叉树的前序递归遍历算法 */ 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); } int main() { printf("请按先序遍历的结果输入树,例如:ABDH#K###E##CFI###G#J##\n"); Create(T); printf("先序遍历的结果为:\n"); PreOrderTraverse(T); printf("\n"); printf("中序遍历的结果为:\n"); InOrderTraverse(T); printf("\n"); printf("后序遍历的结果为:\n"); PostOrderTraverse(T); printf("\n"); return 0; }
PS:遍历的PLus版,想要的自取。
#include #include #include #include #include using namespace std; const int cmax=1e2+5; typedef struct BiTNode { char data; struct BiTNode *lchild ,*rchild; }BiTNode,*BiTree; void CreateBiTree (BiTree &T) { char ch; scanf("%c",&ch); if(ch=='#') T=NULL; else { T=(BiTNode *)malloc(sizeof(BiTNode)); T->data=ch; CreateBiTree(T->lchild); CreateBiTree(T->rchild); } return ; } void PreOrder(BiTree T) { if(T) { printf("%c",T->data); PreOrder(T->lchild); PreOrder(T->rchild); } } void InOrder(BiTree T) { if(T) { InOrder(T->lchild); printf("%c",T->data); InOrder(T->rchild); } } void PostOrder(BiTree T) { if(T) { PostOrder(T->lchild); PostOrder(T->rchild); printf("%c",T->data); } } // 非递归中序遍历 void InOrderTraverse(BiTree T) { stack S; BiTree p; S.push(T); while(!S.empty()) { p=new BiTNode; while((p=S.top())&&p) S.push(p->lchild); S.pop(); if(!S.empty()) { p=S.top(); S.pop(); cout<data<rchild); } } } // 先序非递归遍历 void PreOrder_Nonrecursive(BiTree T) { stack S; BiTree p; S.push(T); while(!S.empty()) { while((p=S.top())&&p) { cout<来源gaodai$ma#com搞$代*码*网data<lchild); } S.pop(); if(!S.empty()) { p=S.top(); S.pop(); S.push(p->rchild); } } } int visit(BiTree T) { if(T) { printf("%c ",T->data); return 1; } else return 0; } // 非递归层次遍历 void LeverTraverse(BiTree T) { queue Q; BiTree p; p=T; if(visit(p)==1) Q.push(p); while(!Q.empty()) { p=Q.front(); Q.pop(); if(visit(p->lchild)==1) Q.push(p->lchild); if(visit(p->rchild)==1) Q.push(p->rchild); } } //主函数 int main() { BiTree T; char j; int flag=1; printf("本程序实现二叉树的操作。\n"); printf("叶子结点以#表示。\n"); printf("可以进行建立二叉树,递归先序、中序、后序遍历,非递归先序、中序遍历及非递归层序遍历等操作。\n"); printf("请建立二叉树。\n"); printf("建树将以三个空格后回车结束。\n"); printf("例如:1 2 3 4 5 6 (回车)\n\n"); CreateBiTree(T); //初始化队列 get以上就是详细了解C语言二叉树的建立与遍历的详细内容,更多请关注gaodaima搞代码网其它相关文章!