码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Leetcode_2:两数相加


    题目描述:

    给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。

    请你将两个数相加,并以相同形式返回一个表示和的链表。

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

    输入:l1 = [2,4,3], l2 = [5,6,4]
    输出:[7,0,8]
    解释:342 + 465 = 807.

    示例 2:

    输入:l1 = [0], l2 = [0]
    输出:[0]
    

    示例 3:

    输入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
    输出:[8,9,9,9,0,0,0,1]
    

    提示:

    • 每个链表中的节点数在范围 [1, 100] 内
    • 0 <= Node.val <= 9
    • 题目数据保证列表表示的数字不含前导零

    思路:

    代码:        

    1. """
    2. @Project :study_python
    3. @File :add two nums.py
    4. @IDE :PyCharm
    5. @Author :chenwenlong
    6. @Date :2023/8/18 22:01
    7. """
    8. # Define single-linked list
    9. class ListNode:
    10. def __init__(self, x):
    11. self.val = x
    12. self.next = None
    13. class Solution:
    14. def addTwoNumbers(self, l1: ListNode, l2: ListNode) -> ListNode:
    15. # 判空
    16. if l1 is None:
    17. return l2
    18. if l2 is None:
    19. return l1
    20. # 准备头结点
    21. dummy = ListNode(0)
    22. carry = 0
    23. p = dummy
    24. # l1 和 l2 都不为空的时候进行运算
    25. while l1 and l2:
    26. # 加进位,注意要求余10,因为可能还会产生进位
    27. p.next = ListNode((l1.val + l2.val + carry)%10)
    28. # 计算进位
    29. carry = (l1.val + l2.val) // 10
    30. l1 = l1.next
    31. l2 = l2.next
    32. p = p.next
    33. # l2为空,l1不为空
    34. if l1:
    35. while l1:
    36. p.next = ListNode((l1.val + carry)%10)
    37. carry = (l1.val + carry) // 10
    38. p = p.next
    39. l1 = l1.next
    40. # l1为空,l2不为空
    41. if l2:
    42. while l2:
    43. p.next = ListNode((l2.val + carry)%10)
    44. carry = (l2.val + carry) // 10
    45. p = p.next
    46. l2 = l2.next
    47. if carry:
    48. p.next = ListNode(carry)
    49. return dummy.next
    50. if __name__ == "__main__":
    51. a = Solution()
    52. listNode1 = ListNode(7)
    53. listNode2 = ListNode(0)
    54. ListNode3 = a.addTwoNumbers(listNode1, listNode2)
    55. print(ListNode3.val)

  • 相关阅读:
    【Vue】数据校验插件开发实例
    【3D图像分割】基于 Pytorch 的 VNet 3D 图像分割3(3D UNet 模型篇)
    @RequestMapping注解最详细解析
    Ebsynth——利用图像处理和计算机视觉的视频风格转换技术
    【pytorch】数据加载dataset和dataloader的使用
    Modbus协议详解3:数据帧格式 - RTU帧 & ASCII帧的区别
    刚刚!ACL 2024公布7篇最佳论文,华中科技大学本科生一作成果获奖
    涛然自得周刊(第 5 期):蝲蛄吟唱的地方
    Express 与 Koa 学习
    hologres按照联合主键删除子查询中的内容,不用in
  • 原文地址:https://blog.csdn.net/AnakinCSDN/article/details/134330429
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号