Skip to main content

Merge Sort On Linked List | Data Structure in C++

Introduction:
Merge Sort: Merge Sort is basically a sorting technique to sort the data. so basically we use it with array.but today we will apply it in linked list.

Problem Statement:
We have given a linked list, and we have to sort it using any sorting technique.

eg: Input: 1->4->5->2->NULL
      Output: 1->2->4->5->NULL

Solution:
To apply merge sort on linked list, we will maintain three function.
1.we should have a function to find the middle of the linked list.(findMid function)
2.we should have a function which will break the linked list into two parts.(mergeSort function)
3.we should have a function which will merge two list in sorted order.(merge function)

Important Point: first of all we have to find the tail of the list. and then we will pass head as well as tail to our merge sort function. kindly go through the code. you will understand each function easily.

Full Code: Merge Sort In C++ On Linked List

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode *findMid(ListNode* l1, ListNode* l2){
        ListNode* slow = l1;
        ListNode* fast = l1;
        while(fast!=l2 && fast->next!=l2){
            slow=slow->next;
            fast=fast->next->next;
        }
        return slow;
    }
   
    ListNode *merge
(ListNode *l1, ListNode *l2){
        ListNode *newlist=NULL;
        ListNode *temp;
       
        while(l1!=NULL && l2!=NULL){
            if(l1->val <= l2->val){
                if(newlist==NULL){
                   newlist = new ListNode();
                   newlist->val = l1->val;
                   newlist->next=NULL;
                    temp=newlist;
                }
                else{
                    ListNode *temp1 = new ListNode();
                    temp1->val=l1->val;
                    temp1->next=NULL;
                    temp->next=temp1;
                    temp=temp1;
                }
                l1=l1->next;
            }
            else{
                if(newlist==NULL){
                   newlist = new ListNode();
                   newlist->val = l2->val;
                   newlist->next=NULL;
                    temp=newlist;
                }
                else{
                    ListNode *temp1 = new ListNode();
                    temp1->val=l2->val;
                    temp1->next=NULL;
                    temp->next=temp1;
                    temp=temp1;
                }
                l2=l2->next;
            }
        }
        while(l1!=NULL){
            ListNode *temp1 = new ListNode();
                    temp1->val=l1->val;
                    temp1->next=NULL;
                    temp->next=temp1;
                    temp=temp1;
                    l1=l1->next;
        }
        while(l2!=NULL){
            ListNode *temp1 = new ListNode();
                    temp1->val=l2->val;
                    temp1->next=NULL;
                    temp->next=temp1;
                    temp=temp1;
                    l2=l2->next;
        }
        return newlist;
           
    }
   
    ListNode *mergeSort(ListNode* left, ListNode *right){
        if(left==right){
            ListNode* temp3 = new ListNode();
            temp3->val=left->val;
            temp3->next=NULL;
            return temp3;
        }
        ListNode* mid = findMid(left,right);
        ListNode* ls = mergeSort(left,mid);
        ListNode* rs = mergeSort(mid->next,right);
        ListNode* nl = merge(ls,rs);
        ListNode* print = nl;
        return nl; 
    }
   
    ListNode* sortList(ListNode* head) {
        if(head==NULL || head->next==NULL)
            return head;
        ListNode* tail = head;
        while(tail->next!=NULL){
            tail=tail->next;
        }
        ListNode *ans = mergeSort(head,tail);
        return ans;
       
           
    }
};

Conclusion:
we are doing all thing, which we do when we perform merge sort on array. first thing is you must know about first node and last node of the list. after that you will find the mid of the list. then call mergesort function on both halves and so on. so there is nothing new except syntax.

Comments

Popular posts from this blog

Disjiont Set Union-Find Data Structure | Code In C++

 Introduction:  In this tutorial we are going to write full program of disjoint set union find advance data structure in c++.  Problem Description: Disjoint Set Union (DSU) is an advance data structure, which basically uses in graph algorithms to find cycles. Codes:  Method1: Brute Force #include<bits/stdc++.h> using namespace std; int find(int f,vector<int>&dsuf){     if(dsuf[f]==-1)         return f;     return find(dsuf[f],dsuf); } void union_op(int from, int to, vector<int>& dsuf){     dsuf[from]=to; } bool isCycle(vector<pair<int,int> >&edge_list, vector<int>&dsuf){     for(int i=0;i<edge_list.size();i++){         int parent1=find(edge_list[i].first,dsuf);         int parent2=find(edge_list[i].second,dsuf);         if(parent1==pare...

Linked List Data Structure | Add Two Number Explanation

Introduction: In this tutorial, we are going to solve a very famous problem on Linked List. It is also an important question for coding interview. so let's see the problem and understand it in detail. Problem Statement: There are two numbers and each digit of number is represented by a node of linked list.and we have to add these two numbers, which is given in the form of linked list. Input: (2 -> 4 -> 3) + (5 -> 6 -> 4) Output: 7 -> 0 -> 8 eg: num1 = 2354;       num2 = 875; see the image below: Solution: Now let's solve it. In this problem there may be three possibilities. First: Number of Nodes in the first linked list is greater than second linked list. Second: Number of Nodes in first linked list is less than second list. Third: Number of Nodes in the both linked list is equal. Here number of nodes means number of digits in both number. Another thing we have to keep in mind is that if we add two digits then there may be possibility of gen...

Integrating Frontend to Backend | MERN stack(100% working)

How to Integrate frontend to backend in MERN stack? For integrating the frontend to backend just do two things. Step1: Go and install cors on both side (front end as well as backend)              To install cors simply open the folder into terminal and type npm install cors--save. step 2: just go to your front end section(react app) open package.json file.                 and just add one line into package.json file.           "proxy":"http://localhost:4000" here i am using 4000, so what is 4000 ?. this is the port  on which our backend is listening. so it may be possible that u may have other port number on which your server is listening. so put yours port number on which your backend server is listening. and this proxy thing we have to add in frontend part not in backend part. Now it may be possible that you want to know ...