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

这篇博客详细解析了LeetCode中第2题——两数相加的问题,难度中等。文章指出,由于数字是以逆序方式存储在链表中,需要在相加过程中考虑进位。作者提供了清晰的解决思路和Python源码实现,帮助理解链表相加的算法。
摘要由CSDN通过智能技术生成

本题为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 ListN
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值