中等 | 单链表 |

一. 题目描述

给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。请你将两个数相加,并以相同形式返回一个表示和的链表。你可以假设除了数字 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. 代码

  1. var addTwoNumbers = function(l1, l2) {
  2. let add = 0;
  3. let dummy = new ListNode(-1,null);
  4. let cur = dummy;
  5. while(l1||l2){
  6. let num1 = l1==null ? 0 : l1.val;
  7. let num2 = l2==null ? 0 : l2.val;
  8. let sum = n1 + n2 + add;
  9. let val = sum % 10;
  10. add = Math.floor(sum/10);
  11. cur.next = new ListNode(val, null);
  12. cur = cur.next;
  13. l1 = l1==null ? l1 : l1.next;
  14. l2 = l2==null ? l2 : l2.next;
  15. }
  16. if(add !== 0){
  17. cur.next = new ListNode(add,null);
  18. }
  19. return dummy.next;
  20. };