单链表的反转-递归

#include <stdio.h>

typedef struct {

int data;

struct Node* next;

}Node;

 

Node* CreateNewNode(int value) {

Node *temp = (Node*)malloc(sizeof(Node));

temp->data = value;

temp->next = NULL;

return temp;

}

Node* CreateLinkedList(Node* head, int value){

Node* temp = CreateNewNode(value);

if(head==NULL) head=temp;

else {

Node* p = head;

while(p->next) { p = p->next;}

p->next = temp;

}

return head;

}

void PrintLinkedList(Node* head){

if(head==NULL) printf("The linkedlist is empty.");

else {

Node* temp=head;

while(temp) {

printf(" %d => ",temp->data);

temp=temp->next;

}

printf("NULL\n");

}

}

Node* ReverseLinkedList(Node* head) {

if(head==NULL||head->next==NULL) {

return head;

}

Node* newNode = ReverseLinkedList(head->next);

Node* next = head->next;

next->next = head;

head->next = NULL;

return newNode;

}

int main()

{

   Node* head=NULL;

   head=CreateLinkedList(head, 1);

   head=CreateLinkedList(head, 2);

   head=CreateLinkedList(head, 3);

   head=CreateLinkedList(head, 4);

   PrintLinkedList(head);

   head=ReverseLinkedList(head);

   PrintLinkedList(head);

   return 0;

}

 1 =>  2 =>  3 =>  4 => NULL

 4 =>  3 =>  2 =>  1 => NULL

 

 

posted @ 2019-08-02 21:21  Lilideng  阅读(336)  评论(0编辑  收藏  举报