C语言数据结构之二叉链表创建二叉树

 更新时间:2022年02月11日 09:39:35   作者:正弦定理  
这篇文章主要介绍了C语言数据结构之 二叉链表创建二叉树,下文我们为了更方便的使用二叉树结构体,可以使用 typedef 对结构体进行命名,具体内容需要的小伙伴可以参考一下

一、思想(先序思想创建)

第一步先创建根节点,然后创建根节点左子树,开始递归创建左子树,直到递归创建到的节点下不继续创建左子树,也就是当下递归到的节点下的左子树指向NULL,结束本次左子树递归,返回这个节点的上一个节点,开始创建右子树,然后又开始以当下这个节点,继续递归创建左子树,左子树递归创建完,就递归创建右子树,直到递归结束返回到上一级指针节点(也就是根节点下),此时根节点左边子树创建完毕,开始创建右边子树,原理和根节点左边创建左右子树相同

二、创建二叉树

二叉树的操作通常使用递归方法,如果递归不太明白,建议去对此进行一下学习和练习。二叉树的操作可以分为两类,一类是需要改变二叉树的结构的,比如二叉树的创建、节点删除等等,这类操作,传入的二叉树的节点参数为二叉树指针的地址,这种参入传入,便于更改二叉树结构体的指针(即地址)。这里稍微有一点点绕,可能需要多思考一下

如下是二叉数创建的函数,这里我规定,节点值为整数,如果输入的数为-1,则表示结束继续往下创建子节点的操作。然后我们使用递归的方法以此创建左子树和右子树

二叉树结构体初始化:

为了更方便的使用二叉树结构体,可以使用 typedef 对结构体进行命名

typedef struct Tree{
 
 int data;                    //    存放数据域
 struct Tree *lchild;            //    遍历左子树指针
 struct Tree *rchild;            //    遍历右子树指针
 
}Tree,*BitTree;

这里展示两种传参类型的创建方法,其中深意可多次参考理解,加深指针理解

(1)传一级参数方法

BitTree CreateLink()
{
    int data;
    int temp;
    BitTree T;
    
    scanf("%d",&data);        //    输入数据
    temp=getchar();            //    吸收空格
    
    if(data == -1){            //    输入-1 代表此节点下子树不存数据,也就是不继续递归创建
        
        return NULL;

    }else{
        T = (BitTree)malloc(sizeof(Tree));            //        分配内存空间
        T->data = data;                                //        把当前输入的数据存入当前节点指针的数据域中
        
        printf("请输入%d的左子树: ",data);        
        T->lchild = CreateLink();                    //        开始递归创建左子树
        printf("请输入%d的右子树: ",data);            
        T->rchild = CreateLink();                    //        开始到上一级节点的右边递归创建左右子树
        return T;                            //        返回根节点
    }    
    
}

(2)传二级参数方法

BitTree CreateLink(BitTree *T)        //    次数 T为指向根节点的指针的地址
{
    int data;    
    
    scanf("%d",&data);

    
    if(data == -1){
        
        *T=NULL;                //    结束递归时,让指针当前节点的指针地址的 指针 指向NULL

    }else{
        
        *T = (BitTree)malloc(sizeof(Tree));        //    对指向节点指针地址的指针 分配内存
    
        if(!(*T) ){            //    *T = NULL  表示分配内存失败,也就是结束递归创建了
            printf("内存分配失败\n");
            exit(-1);
        }
        
        
        (*T)->data = data;        //    给节点指针地址内的数据域,存入数据
        
        printf("请输入%d的左子树: ",data);
        CreateLink(&(*T)->lchild);        //    开始遍历左子树
        printf("请输入%d的右子树: ",data);
        CreateLink(&(*T)->rchild);        //    开始遍历右子树,遍历的思想文章开头处解释
            
    }    
    
}

(1)一级参数完整例子:

#include<stdio.h>
#include<stdlib.h>

typedef struct Tree{
 
 int data;                    //    存放数据域
 struct Tree *lchild;            //    遍历左子树指针
 struct Tree *rchild;            //    遍历右子树指针
 
}Tree,*BitTree;

BitTree CreateLink()
{
    int data;
    int temp;
    BitTree T;
    
    scanf("%d",&data);        //    输入数据
    temp=getchar();            //    吸收空格
    
    if(data == -1){            //    输入-1 代表此节点下子树不存数据,也就是不继续递归创建
        
        return NULL;

    }else{
        T = (BitTree)malloc(sizeof(Tree));            //        分配内存空间
        T->data = data;                                //        把当前输入的数据存入当前节点指针的数据域中
        
        printf("请输入%d的左子树: ",data);        
        T->lchild = CreateLink();                    //        开始递归创建左子树
        printf("请输入%d的右子树: ",data);            
        T->rchild = CreateLink();                    //        开始到上一级节点的右边递归创建左右子树
        return T;                            //        返回根节点
    }    
    
}

void ShowXianXu(BitTree T)            //        先序遍历二叉树
{
    if(T==NULL)
    {
        return;
    }
    printf("%d ",T->data);
    ShowXianXu(T->lchild);            //    递归遍历左子树
    ShowXianXu(T->rchild);            //    递归遍历右子树
}

int main()
{
    BitTree S;
    printf("请输入第一个节点的数据:\n");
    S = CreateLink();            //        接受创建二叉树完成的根节点
    ShowXianXu(S);                //        先序遍历二叉树
    
    return 0;    
} 

(2)二级参数完整例子

#include<stdio.h>
#include<stdlib.h>
typedef struct Tree{
    
    int data;
    struct Tree *lchild;
    struct Tree *rchild;
}Tree,*BitTree;

BitTree CreateLink(BitTree *T)        //    次数 T为指向根节点的指针的地址
{
    int data;    
    
    scanf("%d",&data);

    
    if(data == -1){
        
        *T=NULL;                //    结束递归时,让指针当前节点的指针地址的 指针 指向NULL

    }else{
        
        *T = (BitTree)malloc(sizeof(Tree));        //    对指向节点指针地址的指针 分配内存
    
        if(!(*T) ){            //    *T = NULL  表示分配内存失败,也就是结束递归创建了
            printf("内存分配失败\n");
            exit(-1);
        }
        
        
        (*T)->data = data;        //    给节点指针地址内的数据域,存入数据
        
        printf("请输入%d的左子树: ",data);
        CreateLink(&(*T)->lchild);        //    开始遍历左子树
        printf("请输入%d的右子树: ",data);
        CreateLink(&(*T)->rchild);        //    开始遍历右子树,遍历的思想文章开头处解释
            
    }    
    
}

void ShowXianXu(BitTree T)        //    先序遍历二叉树
{
    if(T==NULL)
    {
        return;
    }
    printf("%d ",T->data);
    ShowXianXu(T->lchild);        //    遍历左子树
    ShowXianXu(T->rchild);        //    遍历右子树
}

int main()
{
    BitTree *S;            //    创建指向这个结构体指针地址 的指针
    printf("请输入第一个节点的数据:\n");
    CreateLink(&S);        //    传二级指针地址
    ShowXianXu(S);        
    
    return 0;    
} 

到此这篇关于C语言数据结构之 二叉链表创建二叉树的文章就介绍到这了,更多相关C语言 二叉链表创建二叉树内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 实例分析一个简单的Win32程序

    实例分析一个简单的Win32程序

    这篇文章主要介绍了实例分析一个简单的Win32程序,对于Win32应用程序的原理、执行流程、实现方法主要环节都做了较为详细的分析,有助于读者深入理解Windows应用程序设计,需要的朋友可以参考下
    2014-09-09
  • C语言实现时间处理工具的示例代码

    C语言实现时间处理工具的示例代码

    这篇文章主要为大家详细介绍了利用C语言实现时间处理工具的相关资料,文中的示例代码讲解详细,具有一定的借鉴价值,需要的可以参考一下
    2022-09-09
  • C++中引用的相关知识点小结

    C++中引用的相关知识点小结

    引用是C++一个很重要的特性,顾名思义是某一个变量或对象的别名,对引用的操作与对其所绑定的变量或对象的操作完全等价,这篇文章主要给大家总结介绍了C++中引用的相关知识点,需要的朋友可以参考下
    2022-03-03
  • C语言实现飞机订票系统的完整代码

    C语言实现飞机订票系统的完整代码

    为了免去在窗口排队买票的麻烦,飞机订票系统应运而生,下面这篇文章主要给大家介绍了关于C语言实现飞机订票系统的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-06-06
  • C/C++字节序的深入理解

    C/C++字节序的深入理解

    本文主要介绍了C/C++字节序的深入理解,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • c++递归解数独方法示例

    c++递归解数独方法示例

    这篇文章主要介绍了c++递归解数独方法示例,需要的朋友可以参考下
    2014-03-03
  • 浅谈C++有理数的表达和计算

    浅谈C++有理数的表达和计算

    这篇文章主要为大家详细介绍了C++有理数的表达和计算,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • c语言中联合体和枚举用法详解

    c语言中联合体和枚举用法详解

    结构体、联合体是C语言中的构造类型,结构体我们平时应该都用得很多,下面这篇文章主要给大家介绍了关于c语言中联合体和枚举用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • STL各个容器性能详细比较

    STL各个容器性能详细比较

    从下面表中的数据来看写入用时vector和deque很快,因为他们内存分配次数少,关联容器和list都是一个一个分配的,一个一个分配也会造成内存碎片,内存利用率低
    2013-09-09
  • Cocos2d-x触摸事件实例

    Cocos2d-x触摸事件实例

    这篇文章主要介绍了Cocos2d-x触摸事件实例,本文代码中包含大量注释来说明Cocos2d-x中的触摸事件使用示例,需要的朋友可以参考下
    2014-09-09

最新评论