|
网站首页
|
业界新闻
|
小组
|
威客
|
人才
|
下载频道
|
博客
|
代码贴
|
在线编程
|
编程论坛
|
登录
注册
短消息
我发表的主题
我参与的主题
我收藏的贴子
我上传的附件
我下过的附件
编辑个人资料
我的博客
用户控制面板
搜索
道具
恢复默认风格
碧海青天
秋意盎然
棕红预览
粉色回忆
蓝雅绿
紫色淡雅
青青河草
e点小镇
橘子红了
红红夜思
水晶紫色
雪花飘飘
新年快乐
风格
短消息
论坛展区
帮助
编程论坛
→
开发语言
→
『 数据结构与算法 』
→ [求助]怎样销毁一个线性表?
我的收件箱(0)
共有
4592
人关注过本帖
标题:
[求助]怎样销毁一个线性表?
只看楼主
加入收藏
x21feng
等 级:
新手上路
帖 子:9
专家分:0
注 册:2006-3-20
楼主
收藏
问题点数:0 回复次数:8
[求助]怎样销毁一个线性表?
如果要销毁一个带头结点的线性表,是直接将head->next置空(即head->next=NULL),还是要全部元素都要使用free()函数将他们释放,又或者是释放head->next就可以了.又或者都不是上边的方法,望高手指点!!
搜索更多相关主题的帖子:
线性表
head
next
结点
2006-03-27 12:20
举报帖子
使用道具
赠送鲜花
sunnvya
等 级:
贵宾
威 望:
17
帖 子:1094
专家分:0
注 册:2005-11-23
第
2
楼
收藏
得分:0
动态分配空间的话,
那些空间一般都得销毁!
而将head->next置空(即head->next=NULL)只是让链表置空,找不到这个链表而已!
http://www. 第二站>>>提供源码下载
2006-03-27 12:46
举报帖子
使用道具
赠送鲜花
qzt040613
等 级:
新手上路
威 望:
6
帖 子:63
专家分:0
注 册:2006-3-15
第
3
楼
收藏
得分:0
free(S),S是链表名
天地无极,我本逍遥!
2006-03-28 12:26
举报帖子
使用道具
赠送鲜花
stnlcd
等 级:
新手上路
帖 子:177
专家分:1
注 册:2004-11-21
第
4
楼
收藏
得分:0
全部元素都要释放,可以写为递归程序:
typedef struct List {
ListType data;
struct List* next;
}List,*PList;
可以写为:
void Destroy_List(PList list) {
if(list) {
Destroy_List(list->next);
free(list); list=NULL;
}
}
list=NULL;是必须要加的,否则后果自负。
要让一个男人破产,请给他一架相机,要让一个男人倾家荡产,请给他一架望远镜。
2006-03-29 09:18
举报帖子
使用道具
赠送鲜花
stnlcd
等 级:
新手上路
帖 子:177
专家分:1
注 册:2004-11-21
第
5
楼
收藏
得分:0
绝对不可以写成free(S),S是链表名的形式!!
要让一个男人破产,请给他一架相机,要让一个男人倾家荡产,请给他一架望远镜。
2006-03-29 11:03
举报帖子
使用道具
赠送鲜花
x21feng
等 级:
新手上路
帖 子:9
专家分:0
注 册:2006-3-20
第
6
楼
收藏
得分:0
以下是引用
stnlcd
在2006-3-29 9:18:00的发言:
全部元素都要释放,可以写为递归程序:
typedef struct List {
ListType data;
struct List* next;
}List,*PList;
可以写为:
void Destroy_List(PList list) {
if(list) {
Destroy_List(list->next);
free(list); list=NULL;
}
}
list=NULL;是必须要加的,否则后果自负。
如不加上list=NULL;该指针还是指向原来的空间,会发生意外.
2006-03-29 19:46
举报帖子
使用道具
赠送鲜花
xuchao501
等 级:
新手上路
帖 子:2
专家分:0
注 册:2008-3-27
第
7
楼
收藏
得分:0
同意4,6
2008-03-27 08:53
举报帖子
使用道具
赠送鲜花
同生缘
等 级:
新手上路
帖 子:32
专家分:0
注 册:2007-11-18
第
8
楼
收藏
得分:0
malloc 与free可以说是
共存的。
2008-08-14 23:30
举报帖子
使用道具
赠送鲜花
geninsf009
等 级:
论坛游民
威 望:
8
帖 子:613
专家分:95
注 册:2008-8-16
第
9
楼
收藏
得分:0
如果从一个程序完美的角度来说,还是要释放所有结点的内存为好,
参考代码:
template <class T>
void
LinkedList<T>::makeEmpty()
{
LinkedNode<T>* ptr=head;//游标指针
LinkedNode<T>* pre;
//指向ptr前个结点的指针
while(ptr!=NULL)
{
pre=ptr;
//保存前个结点指针
ptr=ptr->link;
delete pre;
}
}
一般在析构函数里调用它...
2008-08-16 11:18
举报帖子
使用道具
赠送鲜花
9
1/1页
1
快速回复:
[求助]怎样销毁一个线性表?
数据加载中...
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015902 second(s), 9 queries.
Copyright©2004-2025, BC-CN.NET, All Rights Reserved