数据结构-二叉查找树出现的错误。

发布于 2022-09-02 20:37:38 字数 1267 浏览 9 评论 0

代码如下:

头文件:

ifndef _Tree_H //not defined is true
#define ElementType int

struct TreeNode;
typedef struct TreeNode *Position;
typedef struct TreeNode *SearchTree;

SearchTree MakeEmpty(SearchTree T);
Position Find(ElementType X, SearchTree T);
Position FindMin(SearchTree T);
Position FindMax(SearchTree T);
SearchTree Insert(ElementType X, SearchTree T);
SearchTree Delete(ElementType X, SearchTree T);
ElementType Retrieve(Position p);

#endif // !_Tree_H

struct TreeNode
{
    ElementType Element;
    SearchTree Left;
    SearchTree Right;
};

代码:

#include <stdio.h>
#include <stdlib.h>
#include "tree.h"

SearchTree MakeEmpty(SearchTree T)
{
    if (T != NULL)
    {
        MakeEmpty(T->Left);
        MakeEmpty(T->Right);
        free(T);
    }
    printf("tree is empty");
    return NULL;
}

int main()
{
    SearchTree Tree = (struct TreeNode *)malloc(sizeof(struct TreeNode));
    MakeEmpty(Tree);
    system("pause");
    return 0;
}

刚开始只是测试这个makeempty函数。但是出现了错误。这个函数我觉得很对啊,如果不是空的话就free掉然后去分别free它的左子树和右子树。但是运行时出现错误。
图片描述
他这个为什么无法读取内存。请大家看一下。谢谢。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

昨迟人 2022-09-09 20:37:38

你在生成节点 tree 时,他的左右指针并没有初始化,是野指针,访问会报错

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文