| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4568 人关注过本帖
标题:[求助]怎样销毁一个线性表?
取消只看楼主 加入收藏
x21feng
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2006-3-20
收藏
 问题点数:0 回复次数:1 
[求助]怎样销毁一个线性表?
如果要销毁一个带头结点的线性表,是直接将head->next置空(即head->next=NULL),还是要全部元素都要使用free()函数将他们释放,又或者是释放head->next就可以了.又或者都不是上边的方法,望高手指点!!
搜索更多相关主题的帖子: 线性表 head next 结点 
2006-03-27 12:20
x21feng
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2006-3-20
收藏
得分: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
快速回复:[求助]怎样销毁一个线性表?
数据加载中...
 
   



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

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