鱼C论坛

 找回密码
 立即注册
查看: 2774|回复: 4

麻烦大佬们看看问题到底出在哪??

[复制链接]
发表于 2021-11-16 19:24:23 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
这是创建一个完整的树,实现输入和输出,可问题是为什么就是输出不了呢,编译的时候都是没有错误的,看了好几遍,也没有发现问题的所在,求求大佬们看下给出答案吧
  1. #include<stdio.h>
  2. #include<stdlib.h>

  3. typedef int ElementType;
  4. typedef struct TNode
  5. {
  6.         ElementType data;
  7.         struct TNode *leftchild;
  8.         struct TNode *rightchild;
  9. }TNode,*BinTree;

  10. void CreatBinTree(BinTree T)
  11. {
  12.     ElementType num;
  13.         scanf("%d",&num);
  14.         if(num==0)
  15.         {
  16.                 T=NULL;
  17.         }
  18.         else
  19.         {
  20.                 T=(TNode *)malloc(sizeof(TNode));
  21.                 T->data=num;
  22.                 CreatBinTree(T->leftchild);
  23.                 CreatBinTree(T->rightchild);
  24.         }

  25. }

  26. void PreorderTraverse(BinTree T)
  27. {

  28.                 if(T)
  29.         {
  30.                 printf("%d\n",T->data);
  31.                 PreorderTraverse(T->leftchild);
  32.                 PreorderTraverse(T->rightchild);
  33.         }

  34. }

  35. int main()
  36. {

  37.         BinTree T;
  38.     CreatBinTree(T);
  39.         PreorderTraverse(T);
  40.        
  41.         return 0;
  42. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-11-16 21:00:32 | 显示全部楼层
这玩笑开不得啊  
野指针.png
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-11-16 21:24:58 | 显示全部楼层
  1. #include<stdio.h>
  2. #include<stdlib.h>

  3. typedef int ElementType;
  4. typedef struct TNode {
  5.     ElementType data;
  6.     struct TNode *leftchild;
  7.     struct TNode *rightchild;
  8. } TNode, *BinTree;

  9. BinTree CreatBinTree() {
  10.     BinTree T;
  11.     ElementType num;
  12.     scanf("%d", &num);
  13.     if (num == 0) {
  14.         return NULL;
  15.     } else {
  16.         T = malloc(sizeof (TNode));
  17.         T->data = num;

  18.         T->leftchild = CreatBinTree();
  19.         T->rightchild = CreatBinTree();

  20.     }

  21.     return T;

  22. }

  23. void PreorderTraverse(BinTree T) {

  24.     if (T) {
  25.         printf("%d\n", T->data);
  26.         PreorderTraverse(T->leftchild);
  27.         PreorderTraverse(T->rightchild);
  28.     }

  29. }

  30. int main() {

  31.     BinTree T = CreatBinTree();
  32.     PreorderTraverse(T);

  33.     return 0;
  34. }
复制代码
  
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-11-16 21:25:37 | 显示全部楼层
好像忘了释放内存.....
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-11-16 23:39:12 | 显示全部楼层
最终的执念 发表于 2021-11-16 21:25
好像忘了释放内存.....

哈哈,还是感谢回答,原因我已经找到了,是函数里面指针的问题
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-12 16:02

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表