给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。
请你将两个数相加,并以相同形式返回一个表示和的链表。
你可以假设除了数字 0 之外,这两个数都不会以 0 开头。
示例 1:
输入:l1 = [2,4,3], l2 = [5,6,4]
输出:[7,0,8]
解释:342 + 465 = 807.
示例 2:
输入:l1 = [0], l2 = [0]
输出:[0]
示例 3:
输入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
输出:[8,9,9,9,0,0,0,1]
提示:
每个链表中的节点数在范围 [1, 100] 内
0 <= Node.val <= 9
题目数据保证列表表示的数字不含前导零
ps.力扣已经预设了ListNode类,值为val,后继为next,无须自己定义。
有两种方法可实现功能。不论是使用迭代法还是递归法,当 N 为l1的长度、M为l2的长度时,时间复杂度为O(max(M,N)),若过程中计算result的节点数,则空间复杂度为O(max(M,N)),若不计算,则空间复杂度为 O(1)
迭代法
c++实现
class Solution {
public:
ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
int next1=0; //表示是否有进位
int total=0;
ListNode *result=new ListNode();
ListNode *cur=result; //临时指针,方便移动时不改变result指针的位置
while(l1!=NULL&&l2!=NULL)
{
total=l1->val+l2->val+next1;
cur->next=new ListNode(total%10);
next1=total/10;
l1=l1->next;
l2=l2->next;
cur=cur->next;
}
while(l1!=NULL)//l2遍历到末尾
{
total=l1->val+next1;
cur->next=new ListNode(total%10);
next1=total/10;
l1=l1->next;
cur=cur->next;
}
while(l2!=NULL)//如果是l1遍历到末尾,同理
{
total=l2->val+next1;
cur->next=new ListNode(total%10);
next1=total/10;
l2=l2->next;
cur=cur->next;
}
if(next1!=0)
{cur->next=new ListNode(next1);}
return result->next;
}
};
递归法
c++实现
class Solution {
public:
ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
int total=l1->val+l2->val;
int next1=total/10; //是否有进位
ListNode *result=new ListNode(total%10);
if(l1->next!=NULL||(l2->next!=NULL)||next1!=0)
{
if(l1->next!=NULL)
{l1=l1->next;}
else{l1=new ListNode(0);}
//或写为 l1=l1->next!=NULL?l1->next:new ListNode(0);
if(l2->next!=NULL)
{l2=l2->next;}
else{l2=new ListNode(0);}
//或写为 l2=l2->next!=NULL?l2->next:new ListNode(0);
l1->val+=next1;
result->next=addTwoNumbers(l1,l2);
}
return result;
}