2. Add Two Numbers

问题描述和我的答案:

You are given two non-empty linked lists representing two non-negative integers. The digits are stored in reverse order and each of their nodes contain a single digit. Add the two numbers and return it as a linked list.

You may assume the two numbers do not contain any leading zero, except the number 0 itself.

Example

Input: (2 -> 4 -> 3) + (5 -> 6 -> 4)
Output: 7 -> 0 -> 8
Explanation: 342 + 465 = 807.

看到底下的示例以为用列表做就可以,这道题应该不难,注意使用下面给出的ListNode类,类似于单链表的一个东西。
def addTwoNumbers(self, l1, l2):
        """
        :type l1: ListNode
        :type l2: ListNode
        :rtype: ListNode
        """
        flag = 0
        root = n = ListNode(0)
        while l1 or l2 or flag:
            v1 = v2 = 0
            if l1:
                v1 = l1.val
                l1 = l1.next
            if l2:
                v2 = l2.val
                l2 = l2.next
            val = (v1 + v2 + flag) % 10
            flag = (v1 + v2 + flag) / 10
            n.next = ListNode(val)
            n = n.next
        return root.next
遇到的问题:

1.为什么不能一起在两个列表中进行循环比如for node1, node2 in list1, list2

使用for node1, node2 in zip(list1, list2)来解决的。

2.如何在for循环中保存一个flag留在下次循环使用

这个后期也解决了,根本不是我想的那样,跟C++一样定义一个全局变量是可以使用的。

3.必须使用listNode

def addTwoNumbers(l1,l2):
    """
    :typel1:ListNode
    :typel2:ListNode
    :rtype:ListNode
    """
    flag = 0
    result = []
    for node1, node2 in zip(l1,l2):
        node = (node1+node2)%10+flag
        result.append(node)
        flag = int((node1+node2)/10)
    return result

4.在看别人代码的时候学到divmod的使用,相当于同时进行除法和取余divmod(7, 2) 输出(3, 1)

这个代码也没有问题,对于用列表存储的情况可以给出正确答案。

你可能感兴趣的:(刷题)