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

定义

树的结点

如上图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. 数据结构-

    2024-03-23 10:32:07       41 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-23 10:32:07       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-23 10:32:07       106 阅读
  3. 在Django里面运行非项目文件

    2024-03-23 10:32:07       87 阅读
  4. Python语言-面向对象

    2024-03-23 10:32:07       96 阅读

热门阅读

  1. 日常刷题之88-合并两个有序数组

    2024-03-23 10:32:07       44 阅读
  2. Llama在医学领域的微调模型探索

    2024-03-23 10:32:07       42 阅读
  3. 网络安全知识核心之ARP协议

    2024-03-23 10:32:07       41 阅读
  4. ssh介绍

    ssh介绍

    2024-03-23 10:32:07      35 阅读
  5. 55. 跳跃游戏

    2024-03-23 10:32:07       40 阅读
  6. web蓝桥杯2022省赛真题:冬奥大抽奖

    2024-03-23 10:32:07       46 阅读
  7. golang kafka sarama 源码解析

    2024-03-23 10:32:07       42 阅读
  8. 一些常用的用法

    2024-03-23 10:32:07       42 阅读
  9. IOS面试题编程机制 1-5

    2024-03-23 10:32:07       34 阅读