题目来源:

https://leetcode.com/problems/add-two-numbers/


题意分析:

这道题目是要将两个单链条相加。输出得到的新链条。


题目思路:

不难发现,其实题目就是要我们模拟加法的实现。那么,我们就直接从低位(链条第一位)开始,同位相加,满10就往高位+1。


代码(python):

# Definition for singly-linked list.
# class ListNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution(object):
    def addTwoNumbers(self, l1, l2):
        """
        :type l1: ListNode
        :type l2: ListNode
        :rtype: ListNode
        """
        ans = ListNode(0)
        tmp = ans
        tmpsum = 0
        while True:
            if l1 != None:
                tmpsum += l1.val
                l1 = l1.next
            if l2 != None:
                tmpsum += l2.val
                l2 = l2.next
            tmp.val = tmpsum % 10
            tmpsum //= 10
            if l1 == None and l2 == None and tmpsum == 0:
                break
            tmp.next = ListNode(0)
            tmp = tmp.next
        return ans
        

更多相关文章

  1. python题目——认识*与**,判断函数输出
  2. 嵌入式或LINUX相关研发面试题目
  3. 面试程序员SQL题目?哪位大哥大姐帮我看看 这怎么做? 谢谢
  4. 软件大赛题目----(第一个)Java

随机推荐

  1. android (22)
  2. Android:Galaxy Nexus升级到4.1.2,并root(设
  3. This Android SDK requires Android Deve
  4. Android(1)进程通信基础知识
  5. Android学习之线性布局管理器
  6. Unity与Android通信
  7. Adapter那点事
  8. 要学习android了
  9. android 获取图片
  10. android灵活布局