树的双亲存储

  • 1.perface:

    如下树结构:

    image

    若用树的双亲表示法,结果是:树的双亲表示:

    0  
    1A 
    2B1
    3C1
    4D2
    5E2
    6F2
    7G3
    8H5
    9I5

     

    2.codes://树的双亲表示法存储:

    ..h文件:

    #ifndef TREE_C_H_
    #define TREE_C_H_
    
    
    /**
     * 
     * **/
    
    //树的存储的、结构:
    
    #define M 10
    typedef struct {
        char data;    //字符数据
        int parent; //父节点
    }NODE;
    
    NODE pt[M+1]; //节点数组表示树
    /
    
    typedef struct tnode{
        int child;
        struct tnode *next ; //指向具体的结构的指针
    }TNODE;
    
    typedef  struct tablenode{
        char data;
        TNODE *fchild;//指向第一个孩子的节点
    }TD;
    TD ct[M+1];
    
    //双亲表示法
    void parent_tree(char treedata[M],int m);
    //孩子表示方法
    void child_tree(char treedata[M],int m);
    
    
    #endif /*TREE_C_H_*/
    .c文件:
    /**
             * 双亲的表示法
             * @m 树中的数据
             * */
            void parent_tree(char treedata[M], int m) {
    
                //1.去除数据赋值
                char c;
                int i;
                int j;
                //初始化的头结点:
                pt[0].parent=-1;
                pt[0].data=' ';
                for (i = 0; i <=m; ++i) {
                    pt[i].data=treedata[i];
                    printf("请输入%c的父节点,根的父节点请输入空格\n", pt[i].data);
                    //显出stdout
    
                    fflush(stdout);
                    c=getchar();
                    getchar();//
                    for (j = 0; j < i; ++j) {
                        if (pt[j].data==c) {
                            pt[i].parent=j;
    
                        }
                    }
    
                }
                //输出
                printf("树的双亲表示法:\n");
                printf("下表  data   parent\n");
                for (i = 0; i <m; ++i) {
                    printf("data=%d,parant=%d", pt[i].data, pt[i].parent); //打印出对应的ACII
                    printf("\n");
                }
    
            }
    
    

    3.refence:

    看一下存储的角标确实符合,注意,左边打印的是字符编码。

    image

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

执于代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值