【数据结构】【C/C++】创建二叉树-链式存储-C和C++双语教学

本文详细介绍了使用C语言和C++语言通过链式存储结构创建二叉树的方法,包括定义二叉树节点结构体,递归先序创建二叉树的实现过程,并提供了完整的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、C语言–链式存储二叉树的创建

1、用二叉链表存储,定义结构体

typedef struct BiTreeNode//定义结构体
{
    ElemType  data; //数据域
    struct BiTreeNode *lChild;//左孩子
    struct BiTreeNode *rChlid;//右孩子
} BiTreeNode, *BiTree;

2、递归先序创建二叉树

void CreateBiTree(BiTree *T)//要改变指针,所以要把指针的地址传进来
{
    ElemType ch;
    
    scanf("%d", &ch);//注意数据类型
    getchar();//吸收空格或者回车
    if (ch == -1)
        *T = NULL;
    else
    {
        *T = (BiTree)malloc(sizeof(BiTreeNode));
        
        if (!(*T))//检查是否分配成功
            exit(-1);
            
        (*T)->data = ch;
        CreateBiTree(&(*T)->lChild);//printf("输入%d的左孩子:", ch);
        CreateBiTree(&(*T)->rChlid);//printf("输入%d的右孩子:", ch);
    }
}

3、完整代码

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

typedef int  ElemType; //数据类型

typedef struct BiTreeNode//定义结构体
{
    ElemType  data; //数据域
    struct BiTreeNode *lChild;//左孩子
    struct BiTreeNode *rChlid;//右孩子
} BiTreeNode, *BiTree;
//先序创建二叉树
void CreateBiTree(BiTree *T)//要改变指针,所以要把指针的地址传进来
{
    ElemType ch;
    
    scanf("%d", &ch);//注意数据类型
    getchar();//吸收空格或者回车
    if (ch == -1)
        *T = NULL;
    else
    {
        *T = (BiTree)malloc(sizeof(BiTreeNode));
        
        if (!(*T))//检查是否分配成功
            exit(-1);
            
        (*T)->data = ch;
        CreateBiTree(&(*T)->lChild);//printf("输入%d的左孩子:", ch);
        CreateBiTree(&(*T)->rChlid);//printf("输入%d的右孩子:", ch);
    }
}
int main(void)
{
    BiTree T;

    printf("请输入先序遍历顺序下各个结点的值,-1表示没有结点:\n");
    CreateBiTree(&T);
    
    return 0;
}

二、C+±-链式存储二叉树的创建

1、用二叉链表存储,定义结构体

typedef int  ElemType; //数据类型

typedef struct BiTreeNode//定义结构体
{
    ElemType  data; //数据域
    struct BiTreeNode *lChild;//左孩子
    struct BiTreeNode *rChlid;//右孩子
} BiTreeNode, *BiTree;

2、递归先序创建二叉树
与c语言的区别是,传参时候可以把指针的引用传进来,可以不用malloc分配空间,用new分配,后面的代码更加简洁。

void CreateBiTree(BiTree &T)//要改变指针,C++可以把指针的引用传进来
{
    ElemType ch;

    cin >> ch;

    if (ch == -1)
        T = NULL;
    else
    {
        T = new BiTreeNode;
        T->data = ch;
        CreateBiTree(T->lChild);//cout<<"输入"<<ch<<"的左孩子:" ;
        CreateBiTree(T->rChlid);//cout<<"输入"<<ch<<"的右孩子:" ;
    }
}

3、完整代码

#include<iostream>

using namespace std;

typedef int  ElemType; //数据类型

typedef struct BiTreeNode//定义结构体
{
    ElemType  data; //数据域
    struct BiTreeNode *lChild;//左孩子
    struct BiTreeNode *rChlid;//右孩子
} BiTreeNode, *BiTree;
//先序创建二叉树
void CreateBiTree(BiTree &T)//要改变指针,C++可以把指针的引用传进来
{
    ElemType ch;

    cin >> ch;

    if (ch == -1)
        T = NULL;
    else
    {
        T = new BiTreeNode;
        T->data = ch;
        CreateBiTree(T->lChild);//cout<<"输入"<<ch<<"的左孩子:" ;
        CreateBiTree(T->rChlid);//cout<<"输入"<<ch<<"的右孩子:" ;
    }
}
int main(void)
{
    BiTree T;

    cout<<"请输入先序遍历顺序下各个结点的值,-1表示没有结点:"<<endl;
    CreateBiTree(T);

    return 0;
}

评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值