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
相关推荐
leo__5202 小时前
基于两步成像算法的聚束模式SAR MATLAB实现
开发语言·算法·matlab
前端小白在前进2 小时前
力扣刷题:在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
某林2123 小时前
基于SLAM Toolbox的移动机器人激光建图算法原理与工程实现
stm32·嵌入式硬件·算法·slam
修炼地4 小时前
代码随想录算法训练营第四十三天 | 图论理论基础、深搜理论基础、卡码网98. 所有可达路径、797. 所有可能的路径、广搜理论基础
算法·深度优先·图论
iAkuya4 小时前
(leetcode)力扣100 23反转链表(迭代||递归)
算法·leetcode·链表
剪一朵云爱着4 小时前
PAT 1095 Cars on Campus
算法·pat考试
MicroTech20255 小时前
激光点云快速配准算法创新突破,MLGO微算法科技发布革命性点云配准算法技术
人工智能·科技·算法
Cathy Bryant5 小时前
傅里叶变换(一):简介
笔记·算法·数学建模·信息与通信·傅里叶分析
allan bull6 小时前
在节日中寻找平衡:圣诞的欢乐与传统节日的温情
人工智能·学习·算法·职场和发展·生活·求职招聘·节日
似水এ᭄往昔6 小时前
【C++】--封装红⿊树实现mymap和myset
开发语言·数据结构·c++·算法·stl