(1)注意最后的进位
/**
* 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* addTwoNumbers(ListNode* l1, ListNode* l2) {
ListNode *head=new ListNode(0);
ListNode *p=head,*temp=nullptr;
int sum=0,c=0;
while(l1!=nullptr && l2!=nullptr) {
sum=l1->val+l2->val+c;
if(sum>=10) {
sum-=10;
c=1;
} else c=0;
temp=new ListNode(sum);
p->next=temp;
p=p->next;
l1=l1->next;
l2=l2->next;
}
while(l1!=nullptr) {
sum=l1->val+c;
if(sum>=10) {
sum-=10;
c=1;
} else c=0;
temp=new ListNode(sum);
p->next=temp;
p=p->next;
l1=l1->next;
}
while(l2!=nullptr) {
sum=l2->val+c;
if(sum>=10) {
sum-=10;
c=1;
} else c=0;
temp=new ListNode(sum);
p->next=temp;
p=p->next;
l2=l2->next;
}
if(c==1) {
temp=new ListNode(1);
p->next=temp;
p=p->next;
}
p->next=nullptr;
return head->next;
}
};