1.题目描述
给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照逆序的方式存储的,并且它们的每个节点只能存储 一位 数字。
如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。
您可以假设除了数字 0 之外,这两个数都不会以 0 开头。
2.输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)
输出:7 -> 0 -> 8
原因:342 + 465 = 807
3.解法说明
①.获取两个链表所对应的长度,在较短的链表末尾补零,对齐相加考虑进位。
/**
* 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){
int len1 = 1; //记录l1的长度
int len2 = 1; //记录l2的长度
ListNode* p = l1;
ListNode* q = l2;
while(p->next != Null){
len1++;
p = p->next;
} //获取l1的长度
while(q->next != Null){
len2++;
q = q->next;
} //获取l2的长度
if(len1 > len2){ //l1较长,在l2末尾补零
for(int i = 1; i <= len1 - len2; i++){
q -> next = new ListNode(0);
q = q -> next;
}
}
else //l2较长,在l1末尾补零
{
for(int i = 1; i <= len2 - len1; i++)
{
p -> next = new ListNode(0);
p = p -> next;
}
}
p = l1;
q = l2;
bool count = false; //记录进位
ListNode* l3 = new ListNode(-1); //存放结果的链表
ListNode* w = l3; //l3的移动指针
int i = 0; //记录相加结果
while(p != NULL && q != NULL)
{
i = count + p -> val + q -> val;
w -> next = new ListNode(i % 10);
count = i >= 10 ? true : false;
w = w -> next;
p = p -> next;
q = q -> next;
}
if(count) //若最后还有进位
{
w -> next = new ListNode(1);
w = w -> next;
}
return l3 -> next;
}
};
②.不对齐补零,若链表不为空则用sum(代表每个位的和的结果)加上,考虑进位。
class Solution {
public:
ListNode* addTwoNumbers(ListNode* l1, ListNode* l2)
{
ListNode* head = new ListNode(-1); //存放结果的链表
ListNode* h = head; //移动指针
int sum = 0; //每个位的加和结果
bool carry = false; //进位标志
while(l1 != NULL || l2 != NULL)
{
sum = 0;
if(l1 != NULL)
{
sum += l1 -> val;
l1 = l1 -> next;
}
if(l2 != NULL)
{
sum += l2 -> val;
l2 = l2 -> next;
}
if(carry)
{
sum++;
}
h -> next = new ListNode(sum % 10);
h = h -> next;
carry = sum >= 10 ? true : false;
}
if(carry)
{
h -> next = new ListNode(1);
}
return head -> next;
}
};