搜索
bottom↓
回复: 5

求教:C语言传指针调用函数,malloc申请内存

[复制链接]

出0入0汤圆

发表于 2015-9-16 11:03:21 | 显示全部楼层 |阅读模式
最近在整理一个数据结构书里面的程序,顺便练习下C,在二叉排序树这里有一个插入结点的函数,传进去根节点指针和插入的值,然后递归进行插入排序树,可是根结点的指针进去,申请了内存,返回之后并没有改变根节点的值(仍为NULL);就是单步调试到循环那里,T的值仍为NULL。
//main.c
#include<stdio.h>
#include"tree.h"

void main()
{
        BSTree T = NULL;       
        int i;
        ElemType k[] = {'C','B','A','F','S','D','K'};
        for(i = 0;i < 7;i++)
                BST_Insert(T,k[i]);
        printf("Hello,World\n");
}

/////////////////////////////////////////////////////////////////////////
//tree.h
#ifndef _TREE_H_
#define _TREE_H_

#define MaxSize 100

typedef char ElemType;

typedef struct BSTNode
{
        ElemType data;
        struct TNode * lchild,*rchild;
}BSTNode,*BSTree;
int BST_Insert(BSTree T,ElemType k);
BSTNode *BST_Search(BSTree T,ElemType key,BSTNode *p);
#endif

///////////////////////////////////////////////////
//tree.c
#include"tree.h"
#include<stdio.h>

BSTNode *BST_Search(BSTree T,ElemType key,BSTNode *p)
{
        p = NULL;

        while(T != NULL && T->data != key)
        {
                p = T;
                if(key<T->data)
                {
                        T = T->lchild;
                }
                else
                        T = T->rchild;
        }
        return T;
}
int BST_Insert(BSTree T,ElemType k)
{
        if(T == NULL)
        {
                T =  (BSTree)malloc(sizeof(BSTNode));
                T->data = k;
                T->lchild = T->rchild = NULL;
                return 1;
        }
        else if(k == T->data)
        {
                return 0;
        }
        else if(k<T->data)
        {
                return BST_Insert(T->lchild,k);
        }
        else
        {
                return BST_Insert(T->rchild,k);
        }
}
附上VC6.0的程序。

本帖子中包含更多资源

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

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……

出0入0汤圆

 楼主| 发表于 2015-9-16 11:04:56 | 显示全部楼层
网上百度过,函数里面的栈数据运行完就自动清空,但malloc是在堆上申请的内存,实在是解决不了了,求救。。

出20入25汤圆

发表于 2015-9-16 11:13:50 | 显示全部楼层
要修改指针,需要是使用指针的指针

出0入0汤圆

 楼主| 发表于 2015-9-16 11:46:56 | 显示全部楼层
chenchaoting 发表于 2015-9-16 11:13
要修改指针,需要是使用指针的指针

int BST_Insert(BSTree *T,ElemType k)
{
        if(T == NULL)
        {
                *T =  (BSTree)malloc(sizeof(BSTNode));
                *T->data = k;
                *T->lchild = *T->rchild = NULL;
                return 1;
        }
        else if(k == *T->data)
        {
                return 0;
        }
        else if(k<*T->data)
        {
                return BST_Insert(*T->lchild,k);
        }
        else
        {
                return BST_Insert(*T->rchild,k);
        }
}

函数改成这样吗?我这样改了之后编译就报错了。不好意思,我这水平实在太水,能不能给说的清楚一些,拜谢

出20入25汤圆

发表于 2015-9-16 11:58:16 | 显示全部楼层
   BST_Insert(T,k[i]); 改 BST_Insert(&T,k[i]);

出0入0汤圆

 楼主| 发表于 2015-9-17 08:48:16 | 显示全部楼层
chenchaoting 发表于 2015-9-16 11:58
BST_Insert(T,k); 改 BST_Insert(&T,k);

嗯嗯,我去试试,谢谢
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-8-25 22:10

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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