leetcode hot100 2.两数相加 链表 medium


链表是逆序存储的(个位在头,高位在尾),这反而降低了难度,因为我们可以直接从头节点(个位)开始相加

运算符,名称,作用,在"两数相加"里的意义

  • %,求余。当前位的结果( 0-9)
  • //, 整除 ,进位 (Carry)

逻辑

同时遍历两个链表 l1 和 l2。

  • 处理进位:相加时,每一位的和等于 v1 + v2 + carry(carry 为上一位的进位)
  • 更新进位:当前位的值为 sum % 10,新的进位为 sum // 10。

哑节点:同样使用 ListNode(0) 作为哑节点来简化新链表的构建。

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]:

        prehead = ListNode(-1)
        dummy = prehead
        carry = 0  #  初始值,为了l1 or l2 or carry

        # 只要 l1 有值,或 l2 有值,或还有进位没处理完,就继续循环
        while l1 or l2 or carry:

            # while or,,,即有可能链表已经空了
            if l1:
                v1 = l1.val
            else:
                v1 = 0   # 指向 null 时, 没有val ,则设置他是0

            if l2:
                v2 = l2.val
            else:
                v2 = 0

            total = v1 + v2 + carry
            mod = total % 10  # 求余数,在本位
            carry = total // 10  # 整除,去进位

            # 建立新节点并移动指针
            dummy.next = ListNode(mod)
            dummy = dummy.next

            # 移动原链表指针
            if l1:
                l1 = l1.next
            if l2:
                l2 = l2.next

        
        return prehead.next
        

移动原链表指针 和 建立新节点并移动指针 顺序随意

时间复杂度:O(max(m,n))

其中 m 和 n 分别为两个链表的长度。并行遍历两个链表,循环次数取决于较长的那个数。

空间复杂度:O ( 1 )

只额外使用了常数个指针变量(prehead 和 dummy)

  • 在"两数相加"中:是并行前进的。每走一步,两个链表的指针同时向后移动。总步数取决于最长的那个。O(max⁡(n,m))O(\max(n, m))O(max(n,m)):意味同时(并行)遍历 A 和 B
  • 在"合并两个有序链表"中:是交替前进的。每走一步,只移动其中一个链表的指针(谁小移动谁)。O(n+m)O(n + m)O(n+m)
相关推荐
承渊政道10 小时前
【优选算法】(实战感悟二分查找算法的思想原理)
c++·笔记·学习·算法·leetcode·visual studio code
重生之我是Java开发战士10 小时前
【递归、搜索与回溯】记忆化搜索:斐波那契数列,不同路径,最长递增子序列,猜数字游戏II,矩阵中最长递增路径
算法·leetcode·深度优先
爱吃涮毛肚的肥肥(暂时吃不了版)10 小时前
Leetcode——181.超过经理收入的员工
算法·leetcode·职场和发展
Charlie_lll10 小时前
力扣解题-接雨水
算法·leetcode
We་ct11 小时前
LeetCode 74. 搜索二维矩阵:两种高效解题思路
前端·算法·leetcode·矩阵·typescript·二分查找
_饭团11 小时前
C 语言数据存储全解析:原反补码、大小端与 IEEE 754 浮点数
c语言·数据结构·算法·leetcode·面试·蓝桥杯·学习方法
j_xxx404_11 小时前
力扣--分治(归并排序)算法题II:计算右侧小于当前元素的个数,翻转对(无痛通关困难题)
开发语言·数据结构·c++·算法·leetcode
阿梅要做最快乐的仔11 小时前
链表环问题:快慢指针的经典应用
数据结构·链表
Storynone11 小时前
【Day30】卡码网:46. 携带研究材料,LeetCode:416. 分割等和子集
python·算法·leetcode
噜啦噜啦嘞好11 小时前
算法篇:二分查找
数据结构·c++·算法·leetcode