LC2 两数相加
可以参考的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:节点的值,默认为0next=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

浙公网安备 33010602011771号