Merge two sorted linked lists (Amazon SDE)

Problem - Given two sorted linked lists, merge them so that the resulting linked list is also sorted.

Approach - Create a linked list with NULL value, Maintain a head and tail pointer to traverse the linked lists. Choose head of the merged linked list by comparing the first nodes of both the linked lists, the one with lowest value gets inside the merged linked list. Move pointer one step forward and repeat.

Code- 

typedef node* temp;

node* merge_sorted(temp head1, temp head2)
{
  if(head1==NULL)
  {
    return head2;
  }
  else if(head2==NULL)
  {
    return head1;
  }
  
  temp mergedhead= NULL; //merged head 
  if(head1->data<=head2->data)
  {
    mergedhead=head1;
    head1=head1->next;
  }
  else
  {
    mergedhead=head2;
    head2=head2->next;
  }

  temp mergedtail= mergedhead; //initialise merged tail

  while(head1!=NULL && head2!= NULL)  //update the tail 
  {
    temp val=NULL;
    if(head1->data<=head2->data)
    {
      val=head1;
      head1=head1->next;
    }
    else
    {
      val=head2;
      head2=head2->next;
    }

    mergedtail->next= val;
    mergedtail= val;
  }

  if(head1!=NULL)  //add remaining values
  {
    mergedtail->next=head1;
  }
  else if(head2!=NULL)
  {
    mergedtail->next=head2;
  }
  return mergedtail;
}

Popular posts from this blog

Finding the Subarrays (Hackerearth)

Missing Numbers (Hackerrank)

Find Missing Number (Amazon SDE)