2. Add Two Numbers
Leetcode
題目
Input: l1 = [2,4,3], l2 = [5,6,4]
Output: [7,0,8]
Explanation: 342 + 465 = 807.Input: l1 = [0], l2 = [0]
Output: [0]Input: l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
Output: [8,9,9,9,0,0,0,1]解答
Last updated
Input: l1 = [2,4,3], l2 = [5,6,4]
Output: [7,0,8]
Explanation: 342 + 465 = 807.Input: l1 = [0], l2 = [0]
Output: [0]Input: l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
Output: [8,9,9,9,0,0,0,1]Last updated
var addTwoNumbers = function(l1, l2) {
let arr = new ListNode(0);
const head = arr;
while(l1 || l2) {
const number = (l1?.val || 0) + (l2?.val || 0);
// 原本前一個進位的(arr.val) + 餘數
const val = arr.val + number % 10;
arr.val = val % 10;
const next = Math.floor(number / 10) + Math.floor(val / 10) ;
if(l1 !== null) l1 = l1.next;
if(l2 !== null) l2 = l2.next;
// next: 最尾端 next 有進位的狀況
if(next || l1 || l2) {
arr.next = new ListNode(next);
arr = arr.next;
}
}
return head;
};