一.题目描述
已知一个链表的结点结构为:
struct Node
{
int data;
Node *next;
};
typedef struct Node Node;
已知链表的头结点head,写一个函数把这个链表逆序
二.算法分析
从链表头部开始,建立三个临时节点的引用,分别为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.继续像这样子迭代下去,一直到p3是空为止。
6.最后,把head节点的next指向空,成为逆序链表的尾节点。并且把p1赋值给head,让p1所在的节点成为逆序链表的头节点。(补充:或者p2给head也可以,即为带头结点的链表,头结点的data置空)
三.参考代码
Node * ReverseList(Node *head) //链表逆序
{
if ( head == NULL || head->next == NULL )
return head;
Node *p1 = head ;
Node *p2 = p1->next ;
Node *p3 = p2->next ;
p1->next = NULL ;
while ( p3 != NULL )
{
p2->next = p1 ;
p1 = p2 ;
p2 = p3 ;
p3 = p3->next ;
}
p2->next = p1 ;
head = p2 ;
return head ;
}