Leetcode 2. 两数相加

心路历程:

这道题其实不难,但是依旧不影响我写bug出来。

第一想法是遍历链表获得长度后根据多少位来获取数值,写一半发现逆序下直接挨个累加就行。

注意的点:

1、注意python的幂运算是n**m不是n^m,和Latex数学搞混了。

2、for i in range(len(list))循环时又把list[i]写成i了。

3、可以使用虚拟头节点来链接链表,注意返回时返回虚拟节点下一个节点。

解法:链表遍历

python 复制代码
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def addTwoNumbers(self, l1: Optional[ListNode], l2: Optional[ListNode]) -> Optional[ListNode]:
        # 获取两个数
        t1 = l1
        t2 = l2
        n1, n2 = l1.val, l2.val
        len1, len2 = 0, 0
        while t1.next:
            t1 = t1.next
            len1 += 1
            n1 += t1.val * 10**(len1)

        while t2.next:
            t2 = t2.next
            len2 += 1
            n2 += t2.val * 10**(len2)
            
        dummy_head = ListNode()
        res = n1 + n2
        res = str(res)
        t = dummy_head
        for i in range(len(res)-1, -1, -1):
            num = int(res[i])
            tmp = ListNode(num)
            t.next = tmp
            t = t.next
        return dummy_head.next
相关推荐
小年糕是糕手9 分钟前
【C++】string类(二)
开发语言·数据结构·c++·程序人生·算法·leetcode·数字货币
Tisfy13 分钟前
LeetCode 3573.买卖股票的最佳时机 V:深度优先搜索
算法·leetcode·深度优先
TimelessHaze13 分钟前
算法复杂度分析与优化:从理论到实战
前端·javascript·算法
李玮豪Jimmy13 分钟前
Day42:单调栈part2(42.接雨水、84.柱状图中最大的矩形)
java·算法
yaoh.wang14 分钟前
力扣(LeetCode) 58: 最后一个单词的长度 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
LYFlied22 分钟前
【每日算法】LeetCode239. 滑动窗口最大值
数据结构·算法·leetcode·面试
XiaoHu020724 分钟前
C++ 数据结构关于二叉搜索树
数据结构·算法
CoovallyAIHub26 分钟前
下一代驾驶员监测系统如何工作?视觉AI接管驾驶舱
深度学习·算法·计算机视觉
C雨后彩虹28 分钟前
事件推送问题
java·数据结构·算法·华为·面试
夏鹏今天学习了吗29 分钟前
【LeetCode热题100(76/100)】划分字母区间
算法·leetcode·职场和发展