# 2. Add Two Numbers ## 題目概要 給定兩個非空鏈結串列,將兩個鏈結串列相同位置的節點相加後生成新的鏈結串列返回。 ![](https://i.imgur.com/Tm8CtoJ.png) ## 解題技巧 - 相加總和結果情況有兩種: 1. 當兩數相加小於 10 時,並往下走。 2. 當兩數相加大於 10 時,先將和存起來並取餘數,將餘數放在當前節點上;接著將和除以 10 並以 Math.floor 取出結果的整數部分賦予給 carry,接著再往下。 - 相加到兩個鏈結串列的最後一個節點時,若有進位,就將進位 1 接到鏈結串列最後。 ## 程式碼 ```javascript= /** * Definition for singly-linked list. * function ListNode(val, next) { * this.val = (val===undefined ? 0 : val) * this.next = (next===undefined ? null : next) * } */ /** * @param {ListNode} l1 * @param {ListNode} l2 * @return {ListNode} */ var addTwoNumbers = function(l1, l2) { let dummy = new ListNode(); // 占用頭節點 let cur = dummy; // 用於遍歷 let carry = 0; while(l1 !== null || l2 !== null) { let sum = 0; // 兩個鏈結串列的節點相加 if (l1 !== null) { sum += l1.val; l1 = l1.next; } if (l2 !== null) { sum += l2.val; l2 = l2.next; } // 判斷是否有進位 sum += carry; cur.next = new ListNode(sum % 10); carry = Math.floor(sum / 10); cur = cur.next; } // 判斷最後一個節點相加是否有進位, 如果有就放到鏈結串列的最後 if (carry > 0) { cur.next = new ListNode(carry); } return dummy.next; }; ``` ![](https://i.imgur.com/QQ3mkVC.png)