力扣LeetCode2.两数相加及Python源码实现

本题为LeetCode题库中第2两数相加,难度中等,题目请参考这里。

比较绕的一道题,谈论区的python答案不多而且思路没有讲清楚,这里记录一下。

给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。

如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。

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

示例:

输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)
输出:7 -> 0 -> 8
原因:342 + 465 = 807

解决思路:看清题目要求,用链表实现且按照逆序的方法存储,意思就是链表的开始表示低位,链表的后面表示高位,但是题目要求的是返回一个新的链表表示它们的和,也还是按照 逆序 的方式存储,所以不用管低位高位,就把两个链表相对应的位置进行相加然后把结果保存到一个新的链表中返回就行了。这里要注意的是在相加的时候有进位,要考虑到进位在相加时候的影响。另外就是python中链表的实现。

Python源码实现:按照LeetCode上面的格式进行编写

#Definition for singly-linked list. 官方给出的单向链表的Python定义方式
#class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution:
    def addTwoNumbers(self, l1: ListNode, l2: ListNode) -> ListNode:
        a = 0 #用于表示两数相加的和
        b = 0 #进位
        c = 0 #该位求和之后的数值
        i = 0 
        l = ListNode(0) #创建节点链表用于返回最终结果
        ll = ListNode(0)
        while(True): #循环求和链表中的数值
            if l1 != None and l2 != None: #各种情况的求和
                a = l1.val + l2.val
                l1 = l1.next
                l2 = l2.next
            elif l1 != None:
                a = l1.val
                l1 = l1.next
            else:
                a = l2.val
                l2 = l2.next

            a += c 
            b = a % 10
            c = a // 10

            if i == 0: #开始的情况
                l = ListNode(b)
                ll = l #这里相当于ll和l指向了同一个内存地址,后面对ll的操作也影响了l
            else:
                ll.next = ListNode(b)
                ll = ll.next #实际上是指向了Node b这个节点
            i += 1
            if l1 == None and l2 == None:
                if c != 0:
                    ll.next = ListNode(c) #这里是ll.next指向最后的进位节点
                return l #返回求和链表

 

你可能感兴趣的:(LeetCode)