c语言销()-毁链表为什么一定要用二()级指针,新手求教

书上源代码如下voidDestroy(structStuNode**ph)/*直接用*h的话*/{structStuNode*p;p=*ph;/*如果直接用p=h不行吗?... 书上源代码如下
void Destroy(struct StuNode**ph) /*直接用*h的话*/
{ struct StuNode*p;
p=*ph;/*如果直接用p=h不行吗?*/
while(p!=NULL)
{ *ph=p>-next;
free(p);
p=*ph;
}
printf("已删除\n");
*ph=NULL;
} 如果直接用头指针,h等于最后一个结构体的指针域,这个指针域的指针同样是个空指针,书上说需要对头指针进行“双向传递”所以要用二级指针。
展开
 我来答
geraint0923
2012-08-27 · TA获得超过336个赞
知道小有建树答主
回答量:102
采纳率:100%
帮助的人:117万
展开全部
请注意最后一行的:*ph=NULL;
这里删除链表之后,还需要把链表的头指针置为NULL
如果这个函数的参数只是一个一级的指针,那么在函数中就没办法把链表的头指针给置为NULL了,因为C里面函数调用时,参数是传值的,传进来的一级指针和原来链表的头指针虽然具有相同的值,但是却保存在两个不同的内存单元,这时即使修改了函数里的头指针的值,外面链表的头指针却是没有收到任何影响。
kingfeng588
2012-08-27 · TA获得超过2494个赞
知道大有可为答主
回答量:1475
采纳率:50%
帮助的人:1822万
展开全部
2种都可以,只是有点差别.

Destroy(head);// 返回后head没有被修改为NULL.
// Destroy(&head);// 返回后head被修改为NULL.

测试代码如下:
#include<stdio.h>
#include<stdlib.h>
struct StuNode{
int a;
struct StuNode *next;
};
void Destroy(struct StuNode **ph) /*直接用*h的话*/
{
struct StuNode*p;
p=*ph;/*如果直接用p=h不行吗?*/
while(p!=NULL)
{
*ph=p->next;
free(p);
p=*ph;
}
printf("已删除\n");
*ph=NULL;
}
void Destroy(struct StuNode *h)
{
struct StuNode*p;
p=h;
while(p!=NULL)
{
h=p->next;
free(p);
p=h;
}
printf("已删除\n");
h=NULL;
}
void main()
{
int i;
struct StuNode *head;
struct StuNode *p = (struct StuNode*)malloc(sizeof(struct StuNode));
p->a =0;
p->next = NULL;
head = p;
for(i=1;i<4;i++)
{
p->next = (struct StuNode*)malloc(sizeof(struct StuNode));
p->next->next=NULL;
p=p->next;
p->a = i;
}
Destroy(head);
// Destroy(&head);
}
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式