题目如下所示:
这道题很好理解,直接按照链的顺序,先把数字读出来,然后再直接相加就好了。我最开始用了列表来记录数字,但是后来觉得可以直接操作,把数字读出来,然后再递增地乘上位数。
最后处理输出列表的时候有两种方法,一个是直接对数字动手,用整数除得到最高位的数字,然后对余数进行迭代操作,最终输出链表;还有一种方法是借助字符串来操作,把数字先转成字符串,然后再转成数字,一位一位加入到链表中。我用了第二种方法,感觉比较直观一点😀代码如下:
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution:
def addTwoNumbers(self, l1: ListNode, l2: ListNode) -> ListNode:
result_num = 0
count = 0
while l1:
result_num += l1.val * 10**count
count += 1
l1 = l1.next
count = 0
while l2:
result_num += l2.val * 10**count
count += 1
l2 = l2.next
result = ListNode(0)
for i in str(result_num):
mid = ListNode(int(i))
mid.next = result.next
result.next = mid
return result.next