Sunday, 20 September 2015

Reverse linked list recursive

Problem

Reverse a linked list

Solution

We will solve this by recursion. We will reverse the first link and leave the rest of the reversing on the recursion.

Code

public class ReverseLinkedListRecursive
{
 public static void main(String[] args)
 {
  Node a=new Node(4);
  Node b=new Node(6);
  Node c=new Node(2);
  Node d=new Node(9);
  Node e=new Node(5);
  Node f=new Node(3);
  Node g=new Node(6);
  Node h=new Node(2);
  a.next=b;
  b.next=c;
  c.next=d;
  d.next=e;
  e.next=f;
  f.next=g;
  g.next=h;
  a.printLinkedList();
  Node head=reverseLinkedList(a);
  head.printLinkedList();
 }
 public static Node reverseLinkedList(Node head)
 {
  if(head.next==null)
   return head;
  Node newHead=reverseLinkedList(head.next);
  head.next.next=head;
  head.next=null;
  return newHead;
 }
 static class Node
 {
  public Node next;
  public int value;

  public Node(int value)
  {
   this.value = value;
  }
  public void printLinkedList()
  {
   Node head=this;
   while (head != null)
   {
    System.out.print(head.value + "->");
    head = head.next;
   }
   System.out.println();
  }

 }
}
        

No comments:

Post a Comment