ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

数据结构//C——静态——链式二叉树

2022-02-01 19:30:26  阅读:132  来源: 互联网

标签:pR traverse NULL pNode 链式 pNODE 二叉树 child 数据结构


# include <stdio.h>
# include <malloc.h>

typedef  struct TNode{
    char data;
    struct TNode * pL_child;
    struct TNode * pR_child;
} NODE, * pNODE;

struct TNode * Create_tree();
void Pre_traverse(pNODE);
void IN_traverse(pNODE);
void Post_traverse(pNODE);

int main (void){

    pNODE pNode = Create_tree();

    Pre_traverse(pNode);
    printf("\n");

    IN_traverse(pNode);
    printf("\n");

    Post_traverse(pNode);

    return 0;
}
struct TNode * Create_tree(){
    pNODE pA = (pNODE) malloc(sizeof(NODE));
    pNODE pB = (pNODE) malloc(sizeof(NODE));
    pNODE pC = (pNODE) malloc(sizeof(NODE));
    pNODE pD = (pNODE) malloc(sizeof(NODE));
    pNODE pE = (pNODE) malloc(sizeof(NODE));

    pA->data = 'A';
    pB->data = 'B';
    pC->data = 'C';
    pD->data = 'D';
    pE->data = 'E';

    pA->pL_child = pB;
    pA->pR_child = pC;
    pB->pL_child = NULL;
    pB->pR_child = NULL;
    pC->pL_child = pD;
    pC->pR_child = NULL;
    pD->pL_child = NULL;
    pD->pR_child = pE;
    pE->pL_child = NULL;
    pE->pR_child = NULL;

    return pA;
}
void Pre_traverse(pNODE pNode){
/*
 * 先      访问  根节点
 * 再 先序 访问  左子树
 * 再 先序 访问  右子树
 */
    if(NULL != pNode){
        printf("%c\t", pNode->data);
        if(NULL != pNode->pL_child){
            Pre_traverse(pNode->pL_child);
        }
        if(NULL != pNode->pR_child){
            Pre_traverse(pNode->pR_child);
        }
    }
}
void IN_traverse(pNODE pNode){
    if(NULL != pNode){
        if(NULL != pNode->pL_child){
            IN_traverse(pNode->pL_child);
        }
        printf("%c\t", pNode->data);
        if(NULL != pNode->pR_child){
            IN_traverse(pNode->pR_child);
        }
    }
}
void Post_traverse(pNODE pNode){
    if(NULL != pNode){
        if(NULL != pNode->pL_child){
            Post_traverse(pNode->pL_child);
        }
        if(NULL != pNode->pR_child){
            Post_traverse(pNode->pR_child);
        }
        printf("%c\t", pNode->data);
    }
}

标签:pR,traverse,NULL,pNode,链式,pNODE,二叉树,child,数据结构
来源: https://blog.csdn.net/qq_62819483/article/details/122765579

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有