转载请注明出处。
思想很简单,边遍历边将指针反向,顺便将数据往前移一个单位,这样原来的最后一个节点就变成头节点了。
代码实现如下:
#include<stdio.h>
#include<malloc.h>
typedef struct LNode {
int data;
struct LNode *next;
}LNode,*linkList;
linkList creatLinkList(int n) {//创建一个含n个元素的单链表
linkList head = (linkList)malloc(sizeof(LNode));
linkList p,q;
head->data = n;//记录链表中元素个数
q = head;
for(int i = 0;i < n;i++) {
p = (linkList)malloc(sizeof(LNode));
scanf("%d",&p->data);
q->next = p;
q = p;
}
q->next = NULL;
return head;
}
void listTraverse(linkList q) {
while(q->next) {
printf("%d ",q->next->data);
q = q->next;
}
}
linkList reverseLinkList(linkList head) {
linkL