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等于最后一个结构体的指针域,这个指针域的指针同样是个空指针,书上说需要对头指针进行“双向传递”所以要用二级指针。 展开
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等于最后一个结构体的指针域,这个指针域的指针同样是个空指针,书上说需要对头指针进行“双向传递”所以要用二级指针。 展开
2个回答
展开全部
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);
}
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);
}
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询