p->next=s这一步的意义是什么,这里是如何实现指针p向后移动的,求解释

这是建立链表的代码NODE*Createlink(intlen){NODE*h,*p,*s;p=h=(NODE*)malloc(sizeof(NODE))h->next=... 这是建立链表的代码
NODE *Createlink(int len)

NODE *h, *p, *s;
p=h=(NODE*)malloc(sizeof(NODE))
h->next=NULL;
for(int i=1;i<=len;i++)
{
s=(NODE*)malloc(sizeof(NODE));
scanf("%d",&s->data);
s->next=NULL;
p->next=s;
p=s;
}
return h;

请问
s->next=NULL;
p->next=s;
p=s;
p->next=s这一步的意义是什么,这一段是如何实现指针p向后移动的,没看懂
展开
 我来答
brandn琉璃
2016-07-07 · TA获得超过366个赞
知道小有建树答主
回答量:219
采纳率:0%
帮助的人:67.8万
展开全部

每个链表结点有data域和指针域,p->next就是指针域,存放下一个结点的地址,指针域等于s,就是把s结点的地址存到了next里面,就是把s连接到了链表上,p=s就实现了p向右移动一位

追问
前面你说的我看懂了,p=s还是没看懂,为什么要把s赋给p呢
追答
这个函数不是要创建一个链表吗,p=s就是p走到s那,然后循环,重新创建一个s结点,重复这个步骤,相当于s又放到了现在p后面,这就建好第三个结点了。循环完了就建立了一个长度为len的链表
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式