给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。
如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。
您可以假设除了数字 0 之外,这两个数都不会以 0 开头。
示例:
输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)
输出:7 -> 0 -> 8
原因:342 + 465 = 807
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/add-two-numbers
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
自己写的代码(太臃肿):
class Solution
{
public:
ListNode* addTwoNumbers(ListNode* l1, ListNode* l2)
{
ListNode* addList = new ListNode(INT_MAX); //头结点
ListNode* p = addList; //头指针
int carry = 0;
int tmpsum = 0;
while (NULL != l1 || NULL != l2)
{
if (NULL != l1 && NULL != l2) //如果两个都不为空
{
tmpsum = l1->val + l2->val + carry;
carry = tmpsum / 10;
p->next = new ListNode(tmpsum % 10);
p = p->next;
}
if (NULL == l1 && NULL != l2) //l1空但l2不为空
{
p->next = new ListNode((l2->val+carry)%10);
p = p->next;
if(l2->val+carry > 9)
{
carry = 1;
}
else
{
carry = 0;
}
}
if (NULL == l2 && NULL != l1) //l2空但l1不为空
{
p->next = new ListNode((l1->val+carry)%10);
p = p->next;
if(l1->val+carry > 9)
{
carry = 1;
}
else
{
carry = 0;
}
}
if (l1 != NULL)
{
l1 = l1->next;
}
if (l2 != NULL)
{
l2 = l2->next;
}
}
if (carry > 0) { //最后一个进位
p->next = new ListNode(carry);
}
return addList->next;
}
};
优秀代码(值得学习):
public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
ListNode dummyHead = new ListNode(0);
ListNode p = l1, q = l2, curr = dummyHead;
int carry = 0;
while (p != null || q != null) {
int x = (p != null) ? p.val : 0;
int y = (q != null) ? q.val : 0;
int sum = carry + x + y;
carry = sum / 10;
curr.next = new ListNode(sum % 10);
curr = curr.next;
if (p != null) p = p.next;
if (q != null) q = q.next;
}
if (carry > 0) {
curr.next = new ListNode(carry);
}
return dummyHead.next;
}