Gk158704 2022-05-25 21:16 采纳率: 100%
浏览 29
已结题

我的二叉树代码运行不出来,帮我看看哪里错了

include <stdio.h>

include <stdlib.h>

typedef struct BiTNode{
int data;
struct BiTNode * lchild,* rchild;
}BiTNode,* BiTree;

void initTree(BiTree tree) { //先序遍历创建二叉树
int e;
scanf("%d",&e);
if(e>0){ //输入小于等于0的数表示为空
tree=(BiTree)malloc(sizeof(BiTNode));
tree->data=e;
initTree(tree->lchild);
initTree(tree->rchild);
}
else tree=NULL;
}

void LDR(BiTree tree){ //中序遍历
if(tree){
LDR(tree->lchild);
printf("%4d ",tree->data);
LDR(tree->rchild);
}
}

main(){
BiTree tree=NULL;
initTree(tree);
LDR(tree);
}

输入6 3 0 4 0 0 1 7 0 0 0  最后运行没有输出
  • 写回答

1条回答 默认 最新

  • qzjhjxj 2022-05-26 08:44
    关注

    修改处见注释,供参考:

    #include <stdio.h>
    #include <stdlib.h>
    typedef struct BiTNode {
        int data;
        struct BiTNode* lchild, * rchild;
    }BiTNode, * BiTree;
    
                       //void initTree(BiTree tree) //修改
    void initTree(BiTree* tree) { //先序遍历创建二叉树
        int e;
        scanf("%d", &e);
        if (e > 0) { //输入小于等于0的数表示为空
            (*tree) = (BiTree)malloc(sizeof(BiTNode));
                            //tree=(BiTree)malloc(sizeof(BiTNode));  修改
            (*tree)->data = e;
                            //tree->data=e;      修改
            initTree(&(*tree)->lchild);
                            //initTree(tree->lchild);  修改
            initTree(&(*tree)->rchild);
                           //initTree(tree->rchild);  修改
        }
        else (*tree) = NULL;
                           //else tree=NULL;   修改
    }
    
    void LDR(BiTree tree) { //中序遍历
        if (tree) {
            LDR(tree->lchild);
            printf("%4d ", tree->data);
            LDR(tree->rchild);
        }
    }
    
    int main() {
        BiTree tree = NULL;
        initTree(&tree);  //initTree(tree); 修改
        LDR(tree);
        return 0;
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 6月3日
  • 已采纳回答 5月26日
  • 创建了问题 5月25日

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度