Leetcode 445 Solution
This article provides solution to leetcode question 445 (add-two-numbers-ii).
Access this page by simply typing in "lcs 445" in your browser address bar if you have bunnylol configured.
Leetcode Question Link
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;
}
};