[求助]怎样销毁一个线性表?
如果要销毁一个带头结点的线性表,是直接将head->next置空(即head->next=NULL),还是要全部元素都要使用free()函数将他们释放,又或者是释放head->next就可以了.又或者都不是上边的方法,望高手指点!!
以下是引用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;是必须要加的,否则后果自负。
全部元素都要释放,可以写为递归程序:
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;该指针还是指向原来的空间,会发生意外.