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

定义

树的结点

如上图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;
}

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

相关推荐
你撅嘴真丑7 分钟前
map 与 set容器的应用--话题焦点人物
数据结构
生成论实验室15 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第二篇:阴阳博弈——认知的动力学基础
数据结构·人工智能·科技·神经网络·算法
li16709027027 分钟前
第二十七章:智能指针
c语言·数据结构·c++·visual studio
代码中介商3 小时前
数据结构开篇:从问题到解决方案
数据结构
AKDreamer_HeXY3 小时前
QOJ 12255 - 36 Puzzle 题解
数据结构·c++·数学·算法·icpc·qoj
Rabitebla4 小时前
vector 的骨架:三根指针、模板陷阱与迭代器失效的第一现场
开发语言·数据结构·c++·算法
Sarvartha5 小时前
N 个字符串最长公共子序列(LCS)求解问题
数据结构·算法
m0_629494735 小时前
LeetCode 热题 100-----16.除了自身以外数组的乘积
数据结构·算法·leetcode
迷途之人不知返5 小时前
优先级队列:priority_queue
数据结构·c++
jieyucx6 小时前
Go 零基础数据结构:顺序表(像「排抽屉」一样学增删改查)
java·数据结构·golang