题目:
面试题 02.05. 链表求和。
给定两个用链表表示的整数,每个节点包含一个数位。
这些数位是反向存放的,也就是个位排在链表首部。
编写函数对这两个整数求和,并用链表形式返回结果。
链表:https://leetcode-cn.com/problems/sum-lists-lcci/
示例:
进阶:思考一下,假设这些数位是正向存放的,又该如何解决呢?
思路:
方法比较笨,但好在容易理解,即先分别存储两个链表中的节点值,按照规则计算求和值,再将计算出的值存成链表。
在存储链表节点值和求和时,借助字符串和整型数据类型完成规则的转化。
代码:
# 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:
l1_str, l2_str = "", ""
while l1:
l1_str += str(l1.val)
l1 = l1.next
while l2:
l2_str += str(l2.val)
l2 = l2.next
new_str = str(int(l1_str[::-1])+int(l2_str[::-1]))[::-1]
output = ListNode(int(new_str[0]))
ans = output
for s in new_str[1:]:
curr = ListNode(int(s))
ans.next = curr
ans = ans.next
return output
时间复杂度O(n),空间复杂度O(n).