努力挤进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 各位请问平行检验趋势图这样要怎么调整?说标准差差异太大了
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题
  • ¥15 wpf界面一直接收PLC给过来的信号,导致UI界面操作起来会卡顿
  • ¥15 init i2c:2 freq:100000[MAIXPY]: find ov2640[MAIXPY]: find ov sensor是main文件哪里有问题吗
  • ¥15 运动想象脑电信号数据集.vhdr
  • ¥15 三因素重复测量数据R语句编写,不存在交互作用
  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab