数据结构--树(二叉树)

定义

树的结点

如上图A的结点为2,B的结点为1,树的结点就是最多的那个,这棵树的结点就是3.

树的存储结构

树的存储结构可以是多样的

复制代码
typedef struct BiTNode  /* 结点结构 */
{
   DATATYPE data;		/* 结点数据 */
   struct BiTNode *lchild,*rchild; /* 左右孩子指针 */
}BiTNode;

我们这里只用孩子域,也可以加上双亲或者兄弟域。

二叉树

满二叉树与万全二叉树

如图,这样一个二叉树就是满二叉树,完全二叉树就是满二叉树少了几个结点

但只能少右边的,不能少。

二叉树的编码

如图。

示例代码

这里只展示树的创建销毁与遍历

复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef char DATATYPE;
typedef struct BiTNode  /* 结点结构 */
{
   DATATYPE data;		/* 结点数据 */
   struct BiTNode *lchild,*rchild; /* 左右孩子指针 */
}BiTNode;
char dat[]="abd#g##eh###c#fi##j##";
int ind = 0 ;
void CreateTree(BiTNode** root)
{
    char c = dat[ind++];
    if('#'==c)
    {
        *root = NULL;
    }
    else 
    {
        *root = (BiTNode*)malloc(sizeof(BiTNode));
        (*root)->data = c;
        CreateTree(&((*root)->lchild));
        CreateTree(&((*root)->rchild));
    }
    return ;
}
void DestroyBiTree(BiTNode* root)
{
    if(NULL == root)
    {
        return ;
    }
    DestroyBiTree(root->lchild);
    DestroyBiTree(root->rchild);
    free(root);

}


void PreOrderTraverse(BiTNode* root)
{
    if(NULL == root)
    {
        return ;
    }
    else 
    {
    
        printf("%c",root->data);
        PreOrderTraverse(root->lchild);
        PreOrderTraverse(root->rchild);
    }
}
void InOrderTraverse(BiTNode* root)
{
    if(NULL == root)
    {
        return ;
    }
    else 
    {
        InOrderTraverse(root->lchild);
        printf("%c",root->data);
        InOrderTraverse(root->rchild);
    }
}
void PostOrderTraverse(BiTNode* root)
{
    if(NULL == root)
    {
        return ;
    }
    else 
    {
        PostOrderTraverse(root->lchild);
        PostOrderTraverse(root->rchild);
        printf("%c",root->data);
    }
}
int main(int argc, char *argv[])
{
    BiTNode* root=NULL;
    CreateTree(&root);
    PreOrderTraverse(root);
    printf("\n");
    InOrderTraverse(root);
    printf("\n");
    PostOrderTraverse(root);
    printf("\n");
    DestroyBiTree(root);
    return 0;
}

对于树的遍历,有前、中、后序遍历

相关推荐
十重幻想1 小时前
PTA6-1 使用函数求最大公约数(C)
c语言·数据结构·算法
青岛少儿编程-王老师1 小时前
CCF编程能力等级认证GESP—C++5级—20250927
java·数据结构·c++
胖咕噜的稞达鸭5 小时前
C++中的父继子承:继承方式实现栈及同名隐藏和函数重载的本质区别, 派生类的4个默认成员函数
java·c语言·开发语言·数据结构·c++·redis·算法
笑口常开xpr5 小时前
【C++】模板 - - - 泛型编程的魔法模具,一键生成各类代码
开发语言·数据结构·c++·算法
立志成为大牛的小牛5 小时前
数据结构——十四、构造二叉树(王道408)
数据结构·笔记·学习·程序人生·考研
笑口常开xpr6 小时前
【C++继承】深入浅出C++继承机制
开发语言·数据结构·c++·算法
HQChart6 小时前
HQChart使用教程30-K线图如何对接第3方数据46-DRAWTEXT_FIX数据结构
数据结构·hqchart·k线图
七饭7 小时前
C语言数据结构-排序
c语言·数据结构·排序算法
_dindong9 小时前
基础算法:滑动窗口
数据结构·学习·算法·leetcode·力扣
Voyager_410 小时前
图像处理踩坑:浮点数误差导致的缩放尺寸异常与解决办法
数据结构·图像处理·人工智能·python·算法