LC2 两数相加

2. 两数相加 - 力扣(LeetCode)

可以参考的B站视频讲解链接两数相加


1 题目

给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。

请你将两个数相加,并以相同形式返回一个表示和的链表。

你可以假设除了数字 0 之外,这两个数都不会以 0 开头。

示例 1:

输入:l1 = [2,4,3], l2 = [5,6,4]
输出:[7,0,8]
解释:342 + 465 = 807.

示例 2:

输入:l1 = [0], l2 = [0]
输出:[0]

示例 3:

输入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
输出:[8,9,9,9,0,0,0,1]

2 解题

这个题目最大的难点其实不是思路上的问题,而是对于自定义的单链表ListNode的理解和使用问题。现在就将ListNode类进行适当的解释和使用。

单链表ListNode

首先ListNoded的定义代码是下面这个class

class ListNode:
     def __init__(self, val=0, next=None):
         self.val = val
         self.next = next

1. 类定义

  • class ListNode: 定义了一个名为ListNode的类,表示链表中的一个节点

2. 构造函数 __init__

  • 这是类的初始化方法,在创建新节点时自动调用
  • 有两个参数,都有默认值:
    • val=0:节点的值,默认为0
    • next=None:指向下一个节点的指针,默认为None(表示没有下一个节点)

3. 属性

  • self.val:存储当前节点的数据值
  • self.next:存储对下一个节点的引用(指针)

4.需要注意的地方

  • self.val仅仅表示的是当前节点的数据值而非所有的数据值

  • 这个和数组是完全不一样的使用方法,他的只有通过遍历整个链表才能进行相应的节点位置的判定。

知道了ListNOde的用法之后便可以进行程序的编写了。

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def addTwoNumbers(self, l1: Optional[ListNode], l2: Optional[ListNode]) -> Optional[ListNode]:
        if l1 is None :
            return l2
        if l2 is None:
            return l1
        
        prehead = ListNode(0) #创建一个val为0的单节点
        head = prehead #指针开始的地方
        carry = 0

        while l1 and l2: #同时
            retain = (l1.val + l2.val + carry)%10
            carry = (l1.val + l2.val + carry )//10
            head.next = ListNode(retain)
            l1 = l1.next
            l2 = l2.next
            head = head.next
        
        while l1: # l1 too long
            retain = (l1.val +carry)%10
            carry = (l1.val +carry)//10
            head.next = ListNode(retain)
            l1 = l1.next
            head = head.next
        
        while l2 :
            retain = (l2.val + carry)%10
            carry = (l2.val + carry)//10
            head.next = ListNode(retain)
            l2 = l2.next
            head = head.next
        
        if carry == 1:
            head.next  = ListNode(carry)

        return prehead.next
posted @ 2025-08-26 22:16  AxonoSensei  阅读(11)  评论(0)    收藏  举报