2.两数相加

给你两个非空的链表,表示两个非负的整数。它们每位数字都是按照   逆序   的方式存储的,并且每个节点只能存储   一位   数字。

请你将两个数相加,并以相同形式返回一个表示和的链表。

你可以假设除了数字 0 之外,这两个数都不会以 0  开头。

示例 1:

1
2
3
输入:l1 = [2,4,3], l2 = [5,6,4]
输出:[7,0,8]
解释:342 + 465 = 807.

示例 2:

1
2
输入:l1 = [0], l2 = [0]
输出:[0]

示例 3:

1
2
输入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
输出:[8,9,9,9,0,0,0,1]

链表定义如下:

1
2
3
4
function ListNode(val) {
this.val = val;
this.next = null;
}

输入参数的封装:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
function createListNode(nums) {
nums += "";
var result = null;
for (let i = 0; i < nums.length; i++) {
let row = new ListNode(Number(nums[i]));
if (i > 0) {
row.next = result;
}
result = row;
}
return result;
}
let l1 = createListNode(342);
let l2 = createListNode(465);

实现方式:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
/**
* @param {ListNode} l1
* @param {ListNode} l2
* @return {ListNode}
*/
var addTwoNumbers = function (l1, l2) {
let result = new ListNode(0),
node = result;
while (l1 || l2) {
let r = node.val,
i = (l1 && l1.val) || 0,
j = (l2 && l2.val) || 0,
sum = r + i + j,
m,
n;
if (sum >= 10) {
m = 1;
n = sum - 10;
} else {
m = 0;
n = sum;
}
l1 = l1 && l1.next;
l2 = l2 && l2.next;
node.val = n;

if (m || l1 || l2) {
node.next = new ListNode(m);
node = node.next;
}
}
return result;
};