链表反转--程序员小灰

我们说的链表反转都是指单链表反转,双链表反转【顺序和逆序都是一样的】无意义
链表反转--程序员小灰
链表逆序的本质,就是把每一个节点原本指向下一个节点的next指针倒转过来,指向它的前置节点
链表反转--程序员小灰

针对链表的某个节点,如果要把它的next指针倒转,至少需要三个节点。

让我们从链表头部开始,建立三个临时节点的引用,分别为p1,p2,p3。它们分别指向头节点、第二个节点、第三个节点。
链表反转--程序员小灰
实现链表逆序的完整步骤如下:

1.以p2节点为视角,把p2节点原本指向p3的next指针倒转,指向p1。
链表反转--程序员小灰
2.三个临时节点引用p1,p2,p3分别向后移动一格位置。
链表反转--程序员小灰
3.重复第1步的工作,以p2节点为视角,把p2节点原本指向p3的next指针倒转,指向p1。
链表反转--程序员小灰
4.重复第2步的工作,三个临时节点引用p1,p2,p3分别向后移动一格位置。
链表反转--程序员小灰
5.继续像这样子迭代下去,一直到p2是空为止。
链表反转--程序员小灰
6.最后,把head节点的next指向空,成为逆序链表的尾节点。并且把p1赋值给head,让p1所在的节点成为逆序链表的头节点。
链表反转--程序员小灰