C语言实现二叉链表存储

 更新时间:2018年08月18日 09:17:34   作者:data_heng  
这篇文章主要为大家详细介绍了C语言实现二叉链表存储的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

利用二叉链表存储,并且利用递归的方法实现二叉树的遍历(前序遍历、中序遍历和后续遍历)操作。

c语言具体实现代码如下:

#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
 
typedef int ElemType;//数据类型
//定义二叉树结构,与单链表相似,多了一个右孩子结点
typedef struct BiTNode
{
 ElemType data;
 struct BiTNode *lChild,*rChild;
}BiTNode,*BiTree;
 
//先序创建二叉树
int CreateBiTree(BiTree *T)
{
 ElemType ch;
 ElemType temp;
 scanf("%d",&ch);
 temp=getchar();
 if(ch==-1)
 {
 *T=NULL;
 }
 else
 {
 *T=(BiTree)malloc(sizeof(BiTNode));
 if(!(*T))
 {
 exit(-1);
 }
 (*T)->data=ch;
 printf("输入%d的左子结点:",ch);
 CreateBiTree(&(*T)->lChild);
 printf("输入%d的右子结点:",ch);
 CreateBiTree(&(*T)->rChild);
 }
 return 1;
}
 
//先序遍历二叉树
void TraverseBiTree(BiTree T)
{
 if(T==NULL)
 {
 return;
 }
 printf("%d",T->data);
 TraverseBiTree(T->lChild);
 TraverseBiTree(T->rChild);
}
 
//中序遍历二叉树
void InOrderBiTree(BiTree T)
{
 if(T==NULL)
 {
 return;
 }
 InOrderBiTree(T->lChild);
 printf("%d",T->data);
 InOrderBiTree(T->rChild);
}
 
//后序遍历二叉树
void PostOrderBiTree(BiTree T)
{
 if(T==NULL)
 {
 return;
 }
 PostOrderBiTree(T->lChild);
 PostOrderBiTree(T->rChild);
 printf("%d",T->data);
}
 
//二叉树的深度
int TreeDeep(BiTree T)
{
 int deep=0;
 if(T)
 {
 int leftdeep=TreeDeep(T->lChild);
 int rightdeep=TreeDeep(T->rChild);
 deep=leftdeep>=rightdeep?leftdeep+1:rightdeep+1;
 }
 return deep;
}
 
//求二叉树叶子结点个数
int Leafcount(BiTree T,int &num)
{
 if(T)
 {
 if(T->lChild==NULL&&T->rChild==NULL)
 {
 num++;
 }
 Leafcount(T->lChild,num);
 Leafcount(T->rChild,num);
 }
 return num;
}
 
//主函数
int main(void)
{
 BiTree T;
 BiTree *p=(BiTree *)malloc(sizeof(BiTree));
 int deepth,num=0;
 printf("请输入第一个结点的值,-1表示没有叶结点:\n");
 CreateBiTree(&T);
 printf("先序遍历二叉树:\n");
 TraverseBiTree(T);
 printf("\n");
 printf("中序遍历二叉树:\n");
 InOrderBiTree(T);
 printf("\n");
 printf("后序遍历二叉树:\n");
 PostOrderBiTree(T);
 printf("\n");
 deepth=TreeDeep(T);
 printf("数的深度为:%d",deepth);
 printf("\n");
 Leafcount(T,num);
 printf("数的叶子结点个数为:%d",num);
 printf("\n");
 return 0;
}

得到的结果如下图所示:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 使用mmap实现大文件的复制(单进程和多进程)

    使用mmap实现大文件的复制(单进程和多进程)

    这篇文章主要为大家详细介绍了使用mmap实现大文件的复制,单进程与多进程的两种情况,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • 二分查找算法在C/C++程序中的应用示例

    二分查找算法在C/C++程序中的应用示例

    这篇文章主要介绍了二分查找算法在C/C++程序中的使用示例,文中最后提到了使用二分查找法一个需要注意的地方,需要的朋友可以参考下
    2016-03-03
  • C语言数据结构的时间复杂度和空间复杂度

    C语言数据结构的时间复杂度和空间复杂度

    算法在编写成可执行程序后,运行时需要耗费时间资源和空间(内存)资源 。因此衡量一个算法的好坏,一般是从时间和空间两个维度来衡量的,即时间复杂度和空间复杂度,感兴趣的同学可以参考阅读
    2023-04-04
  • C++ ofstream和ifstream详细用法

    C++ ofstream和ifstream详细用法

    ofstream是从内存到硬盘,ifstream是从硬盘到内存,其实所谓的流缓冲就是内存空间,本文小编就为大家详细介绍C++ ofstream和ifstream用法,需要的朋友可以参考下面文章的具体内容
    2021-09-09
  • C语言直接插入排序算法介绍

    C语言直接插入排序算法介绍

    大家好,本篇文章主要讲的是C语言直接插入排序算法介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12
  • Qt实现简单TCP服务器

    Qt实现简单TCP服务器

    这篇文章主要为大家详细介绍了Qt实现简单TCP服务器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • C++中main函数怎样调用类内函数

    C++中main函数怎样调用类内函数

    这篇文章主要介绍了C++中main函数怎样调用类内函数问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • C++ 如何实现多线程与线程同步

    C++ 如何实现多线程与线程同步

    多线程中的线程同步可以使用,CreateThread,CreateMutex 互斥锁实现线程同步,通过临界区实现线程同步,Semaphore 基于信号实现线程同步,CreateEvent 事件对象的同步,以及线程函数传递单一参数与多个参数的实现方式。
    2021-06-06
  • Matlab利用随机森林(RF)算法实现回归预测详解

    Matlab利用随机森林(RF)算法实现回归预测详解

    这篇文章主要为大家详细介绍了Matlab如何利用随机森林(RF)算法实现回归预测,以及自变量重要性排序的操作,感兴趣的小伙伴可以了解一下
    2023-02-02
  • C语言编程PAT乙级学习笔记示例分享

    C语言编程PAT乙级学习笔记示例分享

    这篇文章主要为大家介绍了C语言编程PAT乙级学习笔记实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05

最新评论