Leetcode刷题(第2题)——两数相加

x33g5p2x  于2022-02-21 转载在 其他  
字(0.9k)|赞(0)|评价(0)|浏览(274)

一、题目描述
给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。请你将两个数相加,并以相同形式返回一个表示和的链表。你可以假设除了数字 0 之外,这两个数都不会以 0 开头。
二、示例

//示例二:
输入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
输出:[8,9,9,9,0,0,0,1]

三、解题思路
思路很简单,主要是注意一些细节的问题,我们新建一个链表用来存放两个链表的累计和,并且使用一个变量enter来保存进位。本题主要的一点是:在最后如果enter的不为0的话,此时需要在最后加上一个新节点,并且其值为1
四、代码

/**
 * 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 newList = new ListNode(0)
    let p = newList
    let curValue = 0
    let enter = 0
    while(l1 || l2) {
        if(l1 && l2) {
            curValue = l1.val + l2.val + enter
            l1 = l1.next
            l2 = l2.next
        }else if(l1) {
            curValue = l1.val + enter
            l1 = l1.next
        }else {
            curValue = l2.val + enter
            l2 = l2.next
        }
        enter = curValue >= 10 ? 1 : 0
        newList.next = new ListNode(curValue % 10)
        newList = newList.next
    }
    if(enter) {
        newList.next = new ListNode(1)
    }
    return p.next
};

五、总结

时间复杂度为O(n),空间复杂度为O(n)。

相关文章