| 编程中国 | 业界新闻 | 技术文章 | 视频教程 | 下载频道 | 程序源码 | 个人空间 | 编程论坛
全能ASP/PHP/ASP.NET主机,支持月付专业 MSSQL 数据库空间,支持月付专业 MySQL 数据库空间,支持月付学习型 ASP/PHP/ASP.NET 主机 30元/年
高端软件开发 = 年薪十万不是梦赛孚耐:软件保护加密专家身份认证令牌USB KEY 
共有 260 人关注过本帖
标题:链式二叉树释放内存问题!
收藏  订阅  推荐  打印 
giant
Rank: 2
等级:注册会员
帖子:180
积分:1900
注册:2005-12-11
链式二叉树释放内存问题!

请问下面的二叉树当输出结果后如何将内存释放掉:(程序是正确的,我只想在inorderTraverse()函数后面加一个释放内存的函数,如何操作,请指教),谢谢

#include<stdio.h>
#include<stdlib.h>
typedef struct BiTNOde{
int data;
struct BiTNOde *lchild,*rchild;
}BiTNode,*BiTree;

BiTree CreateTree(BiTree T,int value);
void InorderTraverse(BiTree T);

int main()
{
BiTree T=NULL;
int i,n,value;

printf("Please input create node number:\n");
scanf("%d",&n);
for(i=1;i<=n;i++) //创建二叉树
{
scanf("%d",&value);
T=CreateTree(T,value);
}
InorderTraverse(T); //中序遍历二叉树
printf("null\n");

return 0;
}

BiTree CreateTree(BiTree T,int value)
{
if(T==NULL)
{
T=(BiTree)malloc(sizeof(BiTNode));
if(T)
{
T->data=value;
T->lchild=NULL;
T->rchild=NULL;
}
else
printf("malloc failure.\n");
}
else
{
if(value < T->data)
T->lchild=CreateTree(T->lchild,value);
if(value > T->data)
T->rchild=CreateTree(T->rchild,value);
}

return T;
}

void InorderTraverse(BiTree T)
{
if(T)
{
InorderTraverse(T->lchild);
printf("%d->",T->data);
InorderTraverse(T->rchild);
}
}

搜索更多相关主题的帖子: 二叉树  链式  内存  BiTree  int  
2006-3-28 22:22
油豆
Rank: 2
等级:注册会员
帖子:67
积分:770
注册:2006-3-29

用一个后序遍历,将visit函数改成free函数就行了.


2006-3-29 20:07
elulue
Rank: 1
等级:新手上路
帖子:7
积分:170
注册:2006-3-24

哈哈.楼上聪明.呵呵.
不过跟楼主的要求不是很一样...我菜.学习各位.
2006-3-29 20:44
油豆
Rank: 2
等级:注册会员
帖子:67
积分:770
注册:2006-3-29

void InorderTraverse(BiTree T)
{
if(T)
{
InorderTraverse(T->lchild);
printf("%d->",T->data);
InorderTraverse(T->rchild);
free(T);//在这里加一个释放函数就行了.
}
}
刚刚没注意楼主的要求,呵呵!


2006-3-29 20:52
关于我们 | 广告合作 | 编程中国 | 清除Cookies | Archiver | WAP | TOP

编程中国 版权所有,并保留所有权利。鲁ICP备08000592号
Powered by Discuz, Processed in 0.063592 second(s), 9 queries.
Copyright©2004-2008, BCCN.NET, All Rights Reserved