Skip to main content

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 generating a carry during the addition. that mean if we add 5 and 7 then it will produce 2 and 1 as carry.

so we have to keep in mind all above points.

We can add two digits and insert it into one of those linked list nodes. or after each addition we will create a new node and store it's result into the new node. this is another approach. i am using second approach for making it simple.

Full Code:

 ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
       ListNode *ans=NULL;
        ListNode *head;//head of new list
        int carry=0;
        while(l1!=NULL && l2!=NULL){
            int x=(l1->val+l2->val+carry)%10;//addition
            carry=(l1->val+l2->val+carry)/10;//check carry
            ListNode *temp=new ListNode(x);//create new node
            temp->next=NULL;
            if(ans==NULL){
                ans=temp;
                head=ans;
            }
            else{
                ans->next=temp;
                ans=temp;
            }
            l1=l1->next;
            l2=l2->next;
        }
        while(l1!=NULL){
              
                int val=(l1->val+carry)%10;
                carry=(l1->val+carry)/10;
           
                 ListNode *temp=new ListNode(val);
                 temp->next=NULL;
                ans->next=temp;
            ans=temp;
            l1=l1->next;
        }
         while(l2!=NULL){
               int val=(l2->val+carry)%10;
                carry=(l2->val+carry)/10;
           
                 ListNode *temp=new ListNode(val); 
             temp->next=NULL;
            ans->next=temp;
            ans=temp;
             l2=l2->next;
        }
         if(carry){
            ListNode* temp=new ListNode(carry);
            temp->next=NULL;
            ans->next=temp;
            ans=temp;
        }
       return head;
    }

so basically what we are doing in this code is, we are taking one node of both linked list, which is present at the same position, we are adding the value of both node and taking a mod of 10, because if the sum will be greater than 9 then we will keep only last digit of sum.

To check there is carry or not, we are dividing the sum(int x) by 10.

now after finding sum and carry, we are creating a new node, putting the value of sum into newly created node.

We are using two while loops:
first while loop will handle the situation when number of nodes in the first linked list is greater than second.
    while(l1!=NULL){
              
                int val=(l1->val+carry)%10;
                carry=(l1->val+carry)/10;
           
                 ListNode *temp=new ListNode(val);
                 temp->next=NULL;
                ans->next=temp;
            ans=temp;
            l1=l1->next;
        }

second while loop will handle the situation, when number of nodes in the second linked list is greater than first.

while(l2!=NULL){
               int val=(l2->val+carry)%10;
                carry=(l2->val+carry)/10;
           
                 ListNode *temp=new ListNode(val); 
             temp->next=NULL;
            ans->next=temp;
            ans=temp;
             l2=l2->next;
        }

now at the end all values of sum is inserted into a new list. which we can track using the head variable.

actually we storing the sum values into a new list.

i hope you got my points.still having any query then you can comment it down.
best of luck.

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...

Target Sum | Backtracking Problem

Introduction: In this tutorial we are going to solve a problem "Target Sum" which is from leetcode. and believe me it's really a good problem to understand Backtracking(Recursion). and if you try to understand the problem as well as code you will get a clear picture of Backtracking. Problem Statement: Link To Problem You are given a list of non-negative integers, a1, a2, ..., an, and a target, S. Now you have 2 symbols + and - . For each integer, you should choose one from + and - as its new symbol. Find out how many ways to assign symbols to make sum of integers equal to target S. Input: nums is [1, 1, 1, 1, 1], S is 3. Output: 5 Explanation: -1+1+1+1+1 = 3 +1-1+1+1+1 = 3 +1+1-1+1+1 = 3 +1+1+1-1+1 = 3 +1+1+1+1-1 = 3 There are 5 ways to assign symbols to make the sum of nums be target 3. Solution: As given in question, we have two operation + and -. so we will make recursive call for + and - . and if we have sum as target and we have reached upto the last ind...

Group Anagrams solution with explanation:Leetcode solution

what is Anagrams? suppose we have two strings and the characters present in both of the strings are same. then both will be called anagram of each other. eg:" rat" and "art" both are anagram of each other. the characters present in both string are same. eg: "raat" and "art" these are not anagrams of each other. and the reason is that the frequency of "a" in "raat" is 2. while the frequency of "a" in "art" is 1. so these are not anagrams of each other. in short two strings will be anagram of each other if they have same characters and the count(frequency) of each and every character must be same in both strings. Solution: There are different ways to solve this question, so here we are going to use Hashmap to solve this question. cause whenever there is need to search we should go with the data structure which use balanced binary tress or hashing. and we know that Hashmap  uses balanced binary trees. so using...