zoukankan      html  css  js  c++  java
  • 二叉树链式结构实现C语言

    #include "string.h"
    #include "stdio.h"
    #include "stdlib.h"
    #include "io.h"
    #include "math.h"
    #include "time.h"

    #define OK 1
    #define ERROR 0
    #define TRUE 1
    #define FALSE 0

    #define MAXSIZE 100 /* 存储空间初始分配量 */

    typedef int Status; /* Status是函数的类型,其值是函数结果状态代码,如OK等 */

    /* 用于构造二叉树********************************** */
    int index=1;
    typedef char String[24]; /* 0号单元存放串的长度 */
    String str;

    Status StrAssign(String T,char *chars)
    {
    int i;
    if(strlen(chars)>MAXSIZE)
    return ERROR;
    else
    {
    T[0]=strlen(chars);
    for(i=1;i<=T[0];i++)
    T[i]=*(chars+i-1);
    return OK;
    }
    }
    /* ************************************************ */

    typedef char TElemType;
    TElemType Nil=' '; /* 字符型以空格符为空 */

    Status visit(TElemType e)
    {
    printf("%c ",e);
    return OK;
    }

    typedef struct BiTNode /* 结点结构 */
    {
    TElemType data; /* 结点数据 */
    struct BiTNode *lchild,*rchild; /* 左右孩子指针 */
    }BiTNode,*BiTree;


    /* 构造空二叉树T */
    Status InitBiTree(BiTree *T)
    {
    *T=NULL;
    return OK;
    }

    /* 初始条件: 二叉树T存在。操作结果: 销毁二叉树T */
    void DestroyBiTree(BiTree *T)
    {
    if(*T)
    {
    if((*T)->lchild) /* 有左孩子 */
    DestroyBiTree(&(*T)->lchild); /* 销毁左孩子子树 */
    if((*T)->rchild) /* 有右孩子 */
    DestroyBiTree(&(*T)->rchild); /* 销毁右孩子子树 */
    free(*T); /* 释放根结点 */
    *T=NULL; /* 空指针赋0 */
    }
    }

    /* 按前序输入二叉树中结点的值(一个字符) */
    /* #表示空树,构造二叉链表表示二叉树T。 */
    void CreateBiTree(BiTree *T)
    {
    TElemType ch;

    /* scanf("%c",&ch); */
    ch=str[index++];

    if(ch=='#')
    *T=NULL;
    else
    {
    *T=(BiTree)malloc(sizeof(BiTNode));
    if(!*T)
    exit(OVERFLOW);
    (*T)->data=ch; /* 生成根结点 */
    CreateBiTree(&(*T)->lchild); /* 构造左子树 */
    CreateBiTree(&(*T)->rchild); /* 构造右子树 */
    }
    }

    /* 初始条件: 二叉树T存在 */
    /* 操作结果: 若T为空二叉树,则返回TRUE,否则FALSE */
    Status BiTreeEmpty(BiTree T)
    {
    if(T)
    return FALSE;
    else
    return TRUE;
    }

    #define ClearBiTree DestroyBiTree

    /* 初始条件: 二叉树T存在。操作结果: 返回T的深度 */
    int BiTreeDepth(BiTree T)
    {
    int i,j;
    if(!T)
    return 0;
    if(T->lchild)
    i=BiTreeDepth(T->lchild);
    else
    i=0;
    if(T->rchild)
    j=BiTreeDepth(T->rchild);
    else
    j=0;
    return i>j?i+1:j+1;
    }

    /* 初始条件: 二叉树T存在。操作结果: 返回T的根 */
    TElemType Root(BiTree T)
    {
    if(BiTreeEmpty(T))
    return Nil;
    else
    return T->data;
    }

    /* 初始条件: 二叉树T存在,p指向T中某个结点 */
    /* 操作结果: 返回p所指结点的值 */
    TElemType Value(BiTree p)
    {
    return p->data;
    }

    /* 给p所指结点赋值为value */
    void Assign(BiTree p,TElemType value)
    {
    p->data=value;
    }

    /* 初始条件: 二叉树T存在 */
    /* 操作结果: 前序递归遍历T */
    void PreOrderTraverse(BiTree T)
    {
    if(T==NULL)
    return;
    printf("%c",T->data);/* 显示结点数据,可以更改为其它对结点操作 */
    PreOrderTraverse(T->lchild); /* 再先序遍历左子树 */
    PreOrderTraverse(T->rchild); /* 最后先序遍历右子树 */
    }

    /* 初始条件: 二叉树T存在 */
    /* 操作结果: 中序递归遍历T */
    void InOrderTraverse(BiTree T)
    {
    if(T==NULL)
    return;
    InOrderTraverse(T->lchild); /* 中序遍历左子树 */
    printf("%c",T->data);/* 显示结点数据,可以更改为其它对结点操作 */
    InOrderTraverse(T->rchild); /* 最后中序遍历右子树 */
    }

    /* 初始条件: 二叉树T存在 */
    /* 操作结果: 后序递归遍历T */
    void PostOrderTraverse(BiTree T)
    {
    if(T==NULL)
    return;
    PostOrderTraverse(T->lchild); /* 先后序遍历左子树 */
    PostOrderTraverse(T->rchild); /* 再后序遍历右子树 */
    printf("%c",T->data);/* 显示结点数据,可以更改为其它对结点操作 */
    }


    int main()
    {
    int i;
    BiTree T;
    TElemType e1;
    InitBiTree(&T);


    StrAssign(str,"ABDH#K###E##CFI###G#J##");

    CreateBiTree(&T);

    printf("构造空二叉树后,树空否?%d(1:是 0:否) 树的深度=%d ",BiTreeEmpty(T),BiTreeDepth(T));
    e1=Root(T);
    printf("二叉树的根为: %c ",e1);

    printf(" 前序遍历二叉树:");
    PreOrderTraverse(T);
    printf(" 中序遍历二叉树:");
    InOrderTraverse(T);
    printf(" 后序遍历二叉树:");
    PostOrderTraverse(T);
    ClearBiTree(&T);
    printf(" 清除二叉树后,树空否?%d(1:是 0:否) 树的深度=%d ",BiTreeEmpty(T),BiTreeDepth(T));
    i=Root(T);
    if(!i)
    printf("树空,无根 ");

    return 0;
    }

  • 相关阅读:
    HDU4731+找规律
    Unable to open c
    珠宝
    allegro添加多个过孔
    STM32硬件复位时间
    Android 系统的四层结构
    AIDL与stub
    devfs,proc,udev
    cdev[典]
    Linux设备管理之权限倾斜——mem、proc、devfs、sysfs、udev(下)
  • 原文地址:https://www.cnblogs.com/nku-wangfeng/p/7635146.html
Copyright © 2011-2022 走看看