• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

详细了解C语言二叉树的建立与遍历

c语言 搞代码 4年前 (2022-01-06) 28次浏览 已收录 0个评论
文章目录[隐藏]

这篇文章主要介绍了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搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:详细了解C语言二叉树的建立与遍历
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址