题目来自PTA
裁判测试程序样例:
不使用额外的节点存储空间做中转
L
是给定单链表,函数Reverse
要返回被逆转后的链表。
#include <stdio.h>
#include <stdlib.h>
typedef int ElementType;
typedef struct Node *PtrToNode;
struct Node {
ElementType Data;
PtrToNode Next;
};
typedef PtrToNode List;
List Read(); /* 细节在此不表 */
void Print( List L ); /* 细节在此不表 */
List Reverse( List L );
int main()
{
List L1, L2;
L1 = Read();
L2 = Reverse(L1);
Print(L1);
Print(L2);
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
5
1 3 4 5 2
输出样例:
1
2 5 4 3 1
分析
初始状态,prev 是NULL,head 指向当前的头节点 A,next 指向 A 节点的下一个节点 B。
将A节点从链表中脱离出来了,然后移动 head 和 next 指针,使它们分别指向 B 节点和 B 的下一个节点 C
连续重复此操作
该题目答案如下:
List Reverse( List L )
{
List Temp, Prev;
Prev = NULL;
while(L)
{
Temp = L->Next;
L->Next = Prev;
Prev = L;
L = Temp;
}
return Prev;
}
按照图示结构书写代码如下:
LINK_NODE *ReverseLink(LINK_NODE *head)
{
LINK_NODE *next;
LINK_NODE *prev = NULL;
while(head != NULL)
{
next = head->next;
head->next = prev;
prev = head;
head = next;
}
return prev;
}