用c语言实现单链表的逆置,能将此程序详细的解释一下吗?

 我来答
三颗葡萄柚
推荐于2019-10-02 · TA获得超过5759个赞
知道小有建树答主
回答量:0
采纳率:69%
帮助的人:0
展开全部

用c语言实现单链表的逆置的方法:

p=head;  
s=p->next; 
while(s->next!=NULL)
t=s->next; 
s->next=p; 
s=t; 
s->next=p; 
head->next->next=NULL;
head->next=s;

p=head;    //p最开始指向头结点
s=p->next; //s最开始指向第一个节点
while(s->next!=NULL)//只要没有到最后一个元素就继续。最后一个元素的next肯定为NULL
{ t=s->next;  //用t指向s后面的那个元素
s->next=p; //把s指向她前面那个,这个时候就实现了逆向了。而且是就地逆向。元素都没有动的
p=s; //然后p向后移动s
s=t; //s向后移动到p
这样到下一轮的时候又可以讲下下个再指向刚才那个下一个。一次内推}
s->next=p;  //当最后一个的时候,还是要指向她的前一个。
head->next->next=NULL;//头指针的下一个是指向原来的第一个。逆向后肯定是最后的那个了。所以最后的一个的next=NULL就明了了。
head->next=s;//s是逆序前的最后一个,逆序后是第一个,所以用头指向他。

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式