数据结构第一轮复习--第五章树、二叉树(包含课程、作业代码)

二叉树的链式存储

复制代码
//二叉树的链式存储
struct ElemType{
	int value;
}; 

typedef struct BiTNode{
	ElemType data;
	struct BiTNode *lchild,*rchild;
}BiTNode,*BiTree;

//定义一颗空树
BiTree root = NULL;

//插入根结点
root = (BiTree)malloc(sizeof(BiTNode));
root->data={1};
root->lchild = NULL;
root->rchild = NULL;

//插入新结点
BiTNode * p = (BiTNode *)malloc(sizeof(BiTNode));
p->data={2};
p->lchild = NULL;
p->rchild = NULL;
root->lchild = p;//作为根结点的左孩子 

其中,struct ElemType 是一个结构体类型,可以包含多种不同类型的数据。在实际应用中,ElemType 的定义可以根据具体需求进行扩展,包含多个字段,以存储更复杂的信息。

复制代码
struct ElemType{
    int value;
};

示例代码:插入一个新结点

假设我们要插入一个新结点,其值为 2,姓名为 "Alice",年龄为 20,可以这样实现:

复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

struct ElemType {
    int value;
    char name[50];
    int age;
};

typedef struct BiTNode {
    ElemType data;
    struct BiTNode *lchild, *rchild;
} BiTNode, *BiTree;

int main() {
    // 定义一颗空树
    BiTree root = NULL;

    // 插入根结点
    root = (BiTree)malloc(sizeof(BiTNode));
    if (root == NULL) {
        printf("Memory allocation failed.\n");
        return -1;
    }
    root->data.value = 1;
    strcpy(root->data.name, "Root");
    root->data.age = 0;
    root->lchild = NULL;
    root->rchild = NULL;

    // 插入新结点
    BiTNode *p = (BiTNode *)malloc(sizeof(BiTNode));
    if (p == NULL) {
        printf("Memory allocation failed.\n");
        return -1;
    }
    p->data.value = 2;
    strcpy(p->data.name, "Alice");
    p->data.age = 20;
    p->lchild = NULL;
    p->rchild = NULL;
    root->lchild = p; // 作为根结点的左孩子

    // 打印根结点和左子结点的信息
    printf("Root: value=%d, name=%s, age=%d\n", root->data.value, root->data.name, root->data.age);
    printf("Left child: value=%d, name=%s, age=%d\n", p->data.value, p->data.name, p->data.age);

    // 释放内存
    free(p);
    free(root);

    return 0;
}
相关推荐
txzrxz7 分钟前
结构体排序,双指针,单调栈
数据结构·算法·双指针算法·单调栈·结构体排序
wWYy.12 分钟前
算法:二叉树最大路径和
数据结构·算法
一条大祥脚40 分钟前
ABC357 基环树dp|懒标记线段树
数据结构·算法·图论
苦藤新鸡1 小时前
50.腐烂的橘子
数据结构·算法
无限进步_1 小时前
面试题 02.02. 返回倒数第 k 个节点 - 题解与详细分析
c语言·开发语言·数据结构·git·链表·github·visual studio
Hello World . .1 小时前
数据结构:栈和队列
c语言·开发语言·数据结构·vim
Yvonne爱编码1 小时前
JAVA数据结构 DAY1-集合和时空复杂度
java·数据结构·python
近津薪荼2 小时前
优选算法——双指针8(单调性)
数据结构·c++·学习·算法
松☆2 小时前
Dart 中的常用数据类型详解(含 String、数字类型、List、Map 与 dynamic) ------(2)
数据结构·list
历程里程碑3 小时前
Linux15 进程二
linux·运维·服务器·开发语言·数据结构·c++·笔记