LeetCode - 两数相加 - JavaScript解法
主要思路就是按位相加,判断是否大于10,然后判断链表末尾是否为0

/**
 * Definition for singly-linked list.
 * function ListNode(val) {
 *     this.val = val;
 *     this.next = null;
 * }
 */
/**
 * @param {ListNode} l1
 * @param {ListNode} l2
 * @return {ListNode}
 */
var addTwoNumbers = function(l1, l2) {
    let head = new ListNode(0);
    let ret = head;
    while(l1 || l2){
        if(l1){
            if(l2){
                ret.val += l1.val + l2.val
                l2 = l2.next;
            }else{
              ret.val += l1.val
                l2 = l2
            }
            l1 = l1.next
        }else{
            if(l2){
              ret.val += l2.val
              l2 = l2.next
            }else{
                l2 = l2
            }
            l1 = l1
        }
        if(ret.val >= 10){
           ret.val = ret.val % 10;
           ret.next = new ListNode(1);
        }
        ret.next = ret.next || new ListNode(0);
        if(l1 == null && l2 == null){
            if(ret.next.val === 0){
                ret.next = null
            }
        }
        ret = ret.next
    }
    return head;
};

相关文章:

  • 2021-11-11
  • 2021-07-23
  • 2021-04-23
  • 2021-11-25
  • 2021-06-01
  • 2021-06-10
  • 2021-08-15
  • 2021-09-08
猜你喜欢
  • 2022-12-23
  • 2021-11-15
  • 2021-09-18
  • 2021-08-02
  • 2022-03-05
  • 2021-08-29
  • 2022-12-23
相关资源
相似解决方案