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

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

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

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

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

  1. /**
  2. * Definition for singly-linked list.
  3. * function ListNode(val, next) {
  4. * this.val = (val===undefined ? 0 : val)
  5. * this.next = (next===undefined ? null : next)
  6. * }
  7. */
  8. /**
  9. * @param {ListNode} l1
  10. * @param {ListNode} l2
  11. * @return {ListNode}
  12. */
  13. var addTwoNumbers = function(l1, l2) {
  14. let newList = new ListNode(0)
  15. let p = newList
  16. let curValue = 0
  17. let enter = 0
  18. while(l1 || l2) {
  19. if(l1 && l2) {
  20. curValue = l1.val + l2.val + enter
  21. l1 = l1.next
  22. l2 = l2.next
  23. }else if(l1) {
  24. curValue = l1.val + enter
  25. l1 = l1.next
  26. }else {
  27. curValue = l2.val + enter
  28. l2 = l2.next
  29. }
  30. enter = curValue >= 10 ? 1 : 0
  31. newList.next = new ListNode(curValue % 10)
  32. newList = newList.next
  33. }
  34. if(enter) {
  35. newList.next = new ListNode(1)
  36. }
  37. return p.next
  38. };

五、总结

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

相关文章