| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 794 人关注过本帖
标题:用new建立二叉树,不编写内存释放函数严不严重
只看楼主 加入收藏
BYSF_XF
Rank: 2
等 级:论坛游民
帖 子:89
专家分:75
注 册:2011-4-25
结帖率:88.89%
收藏
已结贴  问题点数:10 回复次数:2 
用new建立二叉树,不编写内存释放函数严不严重
Tree *create()//前序递归创建二叉树
{
    Tree *head=new Tree;
    char c;
    cin>>c;
    if(c=='#')
        head=NULL;
    else
    {
        head->data=c;
        head->left=create();//创建左子树
        if(head->left==NULL)
            head->l=0;//左子树为空
        head->right=create();//创建右子树
        if(head->right==NULL)
            head->r=0;//右子树为空
    }
    return head;
}
搜索更多相关主题的帖子: 内存 return create 二叉树 
2011-11-07 21:05
yuccn
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:何方
等 级:版主
威 望:167
帖 子:6814
专家分:42393
注 册:2010-12-16
收藏
得分:5 
就你这个代码 已经出现内存泄露了

if(c=='#')
        head=NULL;
这个地方 head本来是块内存的 ,被你指向null,泄露掉一块内存

应该这样:
char c;
cin>>c;
if(c=='#')
    return NULL;

Tree *head=new Tree;
………………
………………
………………

return head;




我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2011-11-08 09:24
Toomj
Rank: 10Rank: 10Rank: 10
等 级:青峰侠
帖 子:257
专家分:1826
注 册:2011-5-17
收藏
得分:5 
那是相当的严重。。。
记住,一个new一个delete,养成好习惯
2011-11-08 09:27
快速回复:用new建立二叉树,不编写内存释放函数严不严重
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015241 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved