一、题目描述给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。请你将两个数相加,并以相同形式返回一个表示和的链表。你可以假设除了数字 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)。
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://blog.csdn.net/weixin_47450807/article/details/123041987
内容来源于网络,如有侵权,请联系作者删除!