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

更新时间:02-01 教程 由 暮夏 分享

算法的核心就是reverse函数,其它的都是辅助建立链表和输出链表的。

从数据结构的定义来看这是一个带头节点的链表。要弄的十分明白你要耐心点画图看看。我简单的说下思路:

【head是指向头结点的】

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是逆序前的最后一个,逆序后是第一个,所以用头指向他

画个图好好体会下,楼主!

声明:关于《用c语言实现单链表的逆置,能将此程序详细的解释一下吗》以上内容仅供参考,若您的权利被侵害,请联系13825271@qq.com
本文网址:http://www.25820.com/tutorial/14_2105532.html