努力挤进IT行业的小白 2023-01-02 15:58 采纳率: 66.7%
浏览 20
已结题

用双亲表示法构造并遍历树

看看那里出现了问题


#include<stdio.h>
#include<stdlib.h>
#include<stdbool.h>

typedef struct ptnode
{
    char data;
    int parent;
}ptnode;

#define MAX 100

typedef struct ptree
{
    ptnode nodes[MAX];
    int n;    //结点数目 
}ptree;

void inittree(ptree &T)
{
    for(int i = 0; i < MAX; i++)
    {
        T.nodes[i].data = '#';
        T.nodes[i].parent = -1;
    }
    T.n = 0;
}

void creattree(ptree &T)           //用双亲表示法建立一颗树 
{
    int e;
    char node;
    printf("请输入树的结点个数:");
    scanf("%d", &T.n);
    printf("请输入%d个树的结点数据:", T.n);
    for(int i = 0; i < T.n; i++)
    {
        scanf("%c ", &node);
        if(node != '#')
        {
            T.nodes[i].data = node;
        }
        else continue;
    }
    printf("请输入结点双亲的的位置:");
    for(int j = 0; j < T.n; j++)
    {
        scanf("%d ", &e);
        if(e != -1)
        {
            T.nodes[j].parent = e;
        }
    }
}

void preorder(ptree &T, int i)
{
    for(int j = 0; j < T.n; j++)
    {
        if(T.nodes[j].parent == i)
        {
            printf("%c", T.nodes[j].data);
            preorder(T, j);
        }
        
    }
}

int main(void)
{
    ptree T;
    inittree(T);
    creattree(T);
    printf("先序遍历树:");
    preorder(T, -1);
    
    
    return 0;
 } 

img

  • 写回答

2条回答 默认 最新

  • qzjhjxj 2023-01-02 18:21
    关注

    两个地方的输入语句做了修改,供参考:

    #include<stdio.h>
    #include<stdlib.h>
    #include<stdbool.h>
    
    typedef struct ptnode
    {
        char data;
        int parent;
    }ptnode;
    
    #define MAX 100
    
    typedef struct ptree
    {
        ptnode nodes[MAX];
        int n;    //结点数目
    }ptree;
    
    void inittree(ptree &T)
    {
        for(int i = 0; i < MAX; i++)
        {
            T.nodes[i].data = '#';
            T.nodes[i].parent = -1;
        }
        T.n = 0;
    }
    
    void creattree(ptree &T)           //用双亲表示法建立一颗树
    {
        int e;
        char node;
        printf("请输入树的结点个数:");
        scanf("%d", &T.n);
        printf("请输入%d个树的结点数据:", T.n);
        for(int i = 0; i < T.n; i++)
        {
            scanf(" %c", &node);
            //scanf("%c ", &node);
            if(node != '#')
            {
                T.nodes[i].data = node;
            }
            else continue;
        }
        printf("请输入结点双亲的的位置:");
        for(int j = 0; j < T.n; j++)
        {
            scanf("%d", &e);
            //scanf("%d ", &e);
            if(e != -1)
            {
                T.nodes[j].parent = e;
            }
        }
    }
    
    void preorder(ptree &T, int i)
    {
        for(int j = 0; j < T.n; j++)
        {
            if(T.nodes[j].parent == i)
            {
                printf("%c", T.nodes[j].data);
                preorder(T, j);
            }
            
        }
    }
    
    int main(void)
    {
        ptree T;
        inittree(T);
        creattree(T);
        printf("先序遍历树:");
        preorder(T, -1);
        
        return 0;
     }
    
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 1月10日
  • 已采纳回答 1月2日
  • 创建了问题 1月2日

悬赏问题

  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)