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;
}