Skip to main content

Program to perform Merge Sort using Linked list

Merge Sort is being done using Divide and Conquer Algorithm.We are going to use linked list for performing the merge sort.I will going to write the functions of the program and not the whole program.




Program :

/* This function takes the head of the linked list and declare two nodes a and b and then split the linked list by calling splitlinkedlist( ) function by passing head and two nodes and then sort recursively each part . */

struct node
{
int data;
struct node*next;
};
void mergesort(struct node *head1)
{
struct node *head=*head1;
struct node *a;
struct node *b;
if (head==NULL||head->next==NULL)
return;
splitlinkedlist(head,&a,&b);
mergesort(&a);                      // Recursively sort the splited nodes
mergesort(&b);
*head1=sort_merge(a,b);
}

/* This function is used to split the linked list from middle, for that we are taking a as a front node and b as back node and we are declaring two new node fast and slow,and then increment fast two times and slow one time such that the fast node reaches to the end and the slow node remain at the middle.Thus splitting the linked list */

void splitlinkedlist(struct node *source,struct node **front,struct node **back)
{
struct node*fast;
struct node*slow;
if(source==NULL||source->next==NULL)
{
*front=source;
*back=NULL;
}
else
{
slow=source;                       //Assign source to slow and fast as source->next
fast=source->next;
}
while(fast!=NULL)            // Iterate the loop till the end and increment fast and slow
{
fast=fast->next;
if(fast!=NULL)
{
fast=fast->next;
slow=slow->next;
}
}
*front=source;                     // Now assign source to front and back to slow->next and make it NULL
*back=slow->next;
slow->next=NULL;
}

/* This function is used to merge the sorted array again to get he final array.For that we define a new node result and compare the data of both nodes and copy the sorted array in the new linked list */

struct node *sort_merge(struct node *a,struct node *b)
{
struct node *result=NULL;
if(a==NULL)                 // If one is NULL return other
return b;
if(b==NULL)
return a;
if(a->data<=b->data)         // compare the data of two nodes and the one which is less is copied to result
{
result=a;
result->next=sort_merge(a->next,b);   // call recursively to merge the sorted array.
}
else
{
result=b;
result->next=sort_merge(a,b->next);
}
}

Also See:
Reverse a doubly linked list
How to reverse a linked list using recursion
          

Comments

Popular posts from this blog

Tricky Questions or Puzzles in C ( Updated for 2026)

Updated for 2026 This article was originally written when C/C++ puzzles were commonly asked in interviews. While such language-specific puzzles are less frequent today, the problem-solving and logical reasoning skills tested here remain highly relevant for modern Software Engineering, Data Engineering, SQL, and system design interviews . Why These Puzzles Still Matter in 2026 Although most Software &   Data Engineering interviews today focus on Programming, SQL, data pipelines, cloud platforms, and system design , interviewers still care deeply about how you think . These puzzles test: Logical reasoning Edge-case handling Understanding of execution flow Ability to reason under pressure The language may change , but the thinking patterns do not . How These Skills Apply to Data Engineering Interviews The same skills tested by C/C++ puzzles appear in modern interviews as: SQL edge cases and NULL handling Data pipeline failure scenarios Incremental vs ...

Programs and Puzzles in technical interviews i faced

I have attended interview of nearly 10 companies in my campus placements and sharing their experiences with you,though i did not got selected in any of the companies but i had great experience facing their interviews and it might help you as well in preparation of interviews.Here are some of the puzzles and programs asked to me in interview in some of the good companies. 1) SAP Labs I attended sap lab online test in my college through campus placements.It had 3 sections,the first one is usual aptitude questions which i would say were little tricky to solve.The second section was Programming test in which you were provided snippet of code and you have to complete the code (See Tricky Code Snippets  ).The code are from different data structures like Binary Tree, AVL Tree etc.Then the third section had questions from Database,OS and Networks.After 2-3 hours we got the result and i was shortlisted for the nest round of interviews scheduled next day.Then the next day we had PPT of t...

Program to uncompress a string ie a2b3c4 to aabbbcccc

Below is the program to uncompress a string #include<stdio.h> #include<conio.h> #include<stdlib.h> int main() { char str[100]="a2b3c4d8u7"; for(int i=0;str[i]!='\0';i++) { if(i%2!=0) { for(int j=0;j<atoi(&str[i]);j++) { printf("%c",str[i-1]); } } } getch(); } Want to become a Data Engineer? Check out below blog posts  1.  5 Key Skills Every Data Engineer needs in 2023 2.  How to prepare for Data Engineering Interviews 3.  Top 25 Data Engineer Questions