Leetcode 445 Solution

This article provides solution to leetcode question 445 (add-two-numbers-ii).

https://leetcode.com/problems/add-two-numbers-ii

Solution

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
        vector<int> v1;
        vector<int> v2;
        
        v1.reserve(1000);
        v2.reserve(1000);
        
        while (l1)
        {
            v1.push_back(l1->val);
            l1 = l1->next;
        }
        
        while (l2)
        {
            v2.push_back(l2->val);
            l2 = l2->next;
        }
        
        int carry = 0;
        ListNode* p = NULL;
        
        while (v1.empty() == false || v2.empty() == false)
        {
            int val1 = 0;
            int val2 = 0;
            
            if (v1.empty() == false)
            {
                val1 = v1.back();
                v1.pop_back();
            }
            
            if (v2.empty() == false)
            {
                val2 = v2.back();
                v2.pop_back();
            }
            
            int val = val1 + val2 + carry;
            
            if (val >= 10)
                val -= 10, carry = 1;
            else
                carry = 0;
            
            if (p == NULL)
                p = new ListNode(val);
            else
            {
                ListNode* q = new ListNode(val);
                q->next = p;
                p = q;
            }
        }
        
        if (carry)
        {
            ListNode* q = new ListNode(1);
            q->next = p;
            p = q;
        }
        
        return p;
    }
};