0
点赞
收藏
分享

微信扫一扫

LC: 面试题 02.05. 链表求和

小贴贴纸happy 2022-05-05 阅读 79

题目:

面试题 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).

举报

相关推荐

0 条评论