• 力扣-python-两数相加


    题解 1:

    1. # Definition for singly-linked list.
    2. # class ListNode(object):
    3. # def __init__(self, val=0, next=None):
    4. # self.val = val
    5. # self.next = next
    6. class Solution(object):
    7. def addTwoNumbers(self, l1, l2):
    8. """
    9. :type l1: ListNode
    10. :type l2: ListNode
    11. :rtype: ListNode
    12. """
    13. carry = 0 # 初始化进位为0
    14. dummy_head = ListNode(0) # 创建一个虚拟头结点
    15. current = dummy_head # 初始化当前节点指向虚拟头结点
    16. while l1 or l2:
    17. x = l1.val if l1 else 0 # 获取l1当前节点的值,如果l1已经遍历完,则为0
    18. y = l2.val if l2 else 0 # 获取l2当前节点的值,如果l2已经遍历完,则为0
    19. # 计算当前位的和,加上进位
    20. _sum = x + y + carry
    21. carry = _sum // 10 # 更新进位
    22. current.next = ListNode(_sum % 10) # 创建新节点,存储当前位的和
    23. current = current.next # 移动current指针
    24. if l1:
    25. l1 = l1.next
    26. if l2:
    27. l2 = l2.next
    28. # 处理最高位可能的进位
    29. if carry > 0:
    30. current.next = ListNode(carry)
    31. return dummy_head.next # 返回结果链表的头节点

    思路 2 :

    假设代码的目标是两个逆序链表l1l2表示的非负整数相加,并返回结果的链表。它使用一个虚拟头结点dummy_head来简化链表操作,同时使用carry变量来跟踪进位。在循环中,它同时处理l1l2上的每个节点,将它们的值相加,加上进位,计算新的进位并创建结果链表。最后,返回结果链表的头节点。

    1. class Solution(object):
    2. def addTwoNumbers(self, l1, l2):
    3. carry = 0 # 初始化进位为0
    4. dummy_head = ListNode() # 创建一个虚拟头结点,无需默认值
    5. current = dummy_head # 初始化当前节点指向虚拟头结点
    6. while l1 or l2 or carry:
    7. # 获取l1和l2当前节点的值,如果l1或l2已经遍历完,则为0
    8. x = l1.val if l1 else 0
    9. y = l2.val if l2 else 0
    10. # 计算当前位的和,加上进位
    11. _sum = x + y + carry
    12. # 计算新的进位值和当前位的结果
    13. carry, result = divmod(_sum, 10)
    14. # 创建新节点,存储当前位的结果
    15. current.next = ListNode(result)
    16. # 移动current指针到新的节点
    17. current = current.next
    18. # 移动到下一个节点,如果l1或l2不为空的话
    19. if l1:
    20. l1 = l1.next
    21. if l2:
    22. l2 = l2.next
    23. return dummy_head.next # 返回结果链表的头节点

    这些是代码的一些改进:

    1. 消耗为ListNode的构造函数提供了默认值,因为默认为None
    2. 使用divmod函数同时计算商和余数,使代码更简洁。
    3. 专业了循环条件,只要l1l2还有值,或者还有进位需要处理,就继续循环。

    1. 多线程任务处理:如果你有一个非常大的链表,你可以将链表分割成多个部分,然后使用多线程任务处理这些部分。这样可以加快计算速度,但需要小心处理线程同步问题。

    2. 使用NumPy数据库:如果链表非常大,并且需要进行大量的数学攻击,可以考虑将链表转换为NumPy数据库,然后使用NumPy提供的矢量化操作执行加法和进位处理。这将显着提高计算速度,但会占用更多内存。

  • 相关阅读:
    Flutter 实现 Android CollapsingToolbarLayout折叠布局效果
    谈谈制定数据治理战略路线图的方法
    JCR一区级 | Matlab实现TCN-LSTM-MATT时间卷积长短期记忆神经网络多特征分类预测
    面试必备:2019年Java 最常见 100+ 面试题解析
    vue2+axios实现注册页面加载动画消息和配置跨域代理
    【Ubuntu】创建C++运行环境
    人工智能基础_机器学习040_Sigmoid函数详解_单位阶跃函数与对数几率函数_伯努利分布---人工智能工作笔记0080
    pytorch(b站小土堆学习笔记P1-P15)
    JavaWeb编程面试题——Spring Web MVC
    java 启动参数 springboot idea
  • 原文地址:https://blog.csdn.net/qq_73454087/article/details/134023423