皮卡丘的妹妹 2022-04-21 11:42 采纳率: 57.1%
浏览 44
已结题

递归遍历二叉树,然后先序中序后序输出,可以看看我的代码问题出在哪吗

#include
#include<stdio.h>
#include<stdlib.h>
using namespace std;

typedef struct BiTNode
{
char data;
struct BiTNode *lchild,*rchild;
}BiTNode,*BinTree;

int InitList(BinTree &T)
{
T=(BinTree)malloc(sizeof(BiTNode));
T->data=NULL;
T->lchild=T->rchild=NULL;

}

void CreatBiTree(BinTree &T)
{

char ch;
ch=getchar();
if(ch=='#') T=NULL;
else 
{

    T->data=ch;
    CreatBiTree((T)->lchild);
    CreatBiTree((T)->rchild);    
}

}

void preorder(BinTree &T)
{

if(T==NULL)
{
    return;
}
else
{
    cout << T->data;
    preorder(T->lchild);
    preorder(T->rchild);
}

}

void inorder(BinTree &T)
{

if(T==NULL)
{
    return;
}
else
{
    inorder(T->lchild);
    cout << T->data;
    inorder(T->rchild);
}

}

void posorder(BinTree &T)
{

if(T==NULL)
{
    return;
}
else
{
    posorder(T->lchild);
    posorder(T->rchild);
    cout << T->data;
}

}

int main()
{
BinTree T;
InitList(T);
CreatBiTree(T);
preorder(T);
cout << endl;
inorder(T);
cout << endl;
posorder(T);
cout << endl;
return 0;
}

帮我看看代码问题出在哪,修改错误

  • 写回答

3条回答 默认 最新

  • 关注

    CreatBiTree函数中每次都要用 T = (BinTree)malloc(sizeof(BiTNode)); 创建新的子节点
    你题目的解答代码如下:

    void CreatBiTree(BinTree &T)
    {
        char ch;
        ch = getchar();
        if (ch == '#')
            T = NULL;
        else
        {
            T = (BinTree)malloc(sizeof(BiTNode)); //加上
            T->data = ch;
            CreatBiTree((T)->lchild);
            CreatBiTree((T)->rchild);
        }
    }
    

    img

    如有帮助,请点击我的回答下方的【采纳该答案】按钮帮忙采纳下,谢谢!

    img

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

报告相同问题?

问题事件

  • 系统已结题 5月4日
  • 已采纳回答 4月26日
  • 修改了问题 4月21日
  • 修改了问题 4月21日
  • 展开全部

悬赏问题

  • ¥15 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!