#include<stdio.h>
#include<stdlib.h>
typedef struct node
{
char data;
struct node*next;
}LNode;
LNode*CreateLinkList()
{
LNode*head,*p,*q;
char x;
head=(LNode*)malloc(sizeof(LNode));
head->next=NULL;
p=head;
q=p;
printf("Input any char string:\n");
scanf("%c",&x);
while(x!='\n')
{
p=(LNode*)malloc(sizeof(LNode));
p->data=x;
p->next=NULL;
q->next=p;
q=p;
scanf("%c",&x);
}
return head;
}
LNode*Reverse(LNode*head)
{
LNode*p,*q,*r;
p=head;
q=r=NULL;
printf("Loading...\n");
while(p)
{
q = p->next;
p->next = r;
r = p;
p = q;
}
printf("Ready!\n");
return r;
}
void print(LNode*h)
{
LNode*p;
p=h;
while(p)
{
printf("%c",p->data);
p=p->next;
}
printf("\n");
}
int main()
{
LNode*h,*p;
int i;
char x;
h=CreateLinkList();
h=Reverse(h);
printf("Reverse LinkList:\n");
print(h);
}