Thursday, September 18, 2014

Reversing linked list iteratively and recursively

Will update this later.
1. Iterative,

Use a dummy node

2. Recursive
http://stackoverflow.com/questions/2434411/linked-list-recursive-reverse
http://www.ym910.com/wp/?p=4408
void RecursiveReverse(struct node** headRef) {

struct node* first;

struct node* rest;

if (*headRef == NULL) return; // empty list base case

first = *headRef; // suppose first = {1, 2, 3}

rest = first->next; // rest = {2, 3}

if (rest == NULL) return; // empty rest base case

RecursiveReverse(&rest); // Recursively reverse the smaller {2, 3} case

// after: rest = {3, 2}

first->next->next = first; // put the first elem on the end of the list

first->next = NULL; // (tricky step -- make a drawing)

*headRef = rest; // fix the head pointer

}
 


No comments:

Post a Comment