中等 | 单链表 |
一. 题目描述
给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。请你将两个数相加,并以相同形式返回一个表示和的链表。你可以假设除了数字 0 之外,这两个数都不会以 0 开头。
二. 题目示例
:::tips
输入: l1 = [2,4,3], l2 = [5,6,4]
输出: [7,0,8]
:::
:::tips
输入: l1 = [0], l2 = [0]
输出: [0]
:::
:::tips
输入: l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
输出: [8,9,9,9,0,0,0,1]
:::
三. 题目解答
1. 思路
取链表当前节点的值和进位值 三者相加,计算新的进位;循环至链表结尾。最后判断是否有剩余进位。
2. 代码
var addTwoNumbers = function(l1, l2) {
let add = 0;
let dummy = new ListNode(-1,null);
let cur = dummy;
while(l1||l2){
let num1 = l1==null ? 0 : l1.val;
let num2 = l2==null ? 0 : l2.val;
let sum = n1 + n2 + add;
let val = sum % 10;
add = Math.floor(sum/10);
cur.next = new ListNode(val, null);
cur = cur.next;
l1 = l1==null ? l1 : l1.next;
l2 = l2==null ? l2 : l2.next;
}
if(add !== 0){
cur.next = new ListNode(add,null);
}
return dummy.next;
};