LeetCode2.两数相加

题目

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

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

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

示例

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

思路

当我们需要将两个逆序表示的非负整数链表相加时,可以使用一个循环来遍历两个链表的每一位,并同时进行相加操作。在这个过程中,我们需要考虑进位的情况。

具体的思路如下:

  • 创建一个虚拟头节点 dummy,并用一个指针 cur 指向该节点。
  • 初始化一个变量 carry 用于存储进位值,初始值为 0。
  • 遍历两个链表 l1 和 l2 直到两个链表都到达末尾并且没有进位:
    • 计算当前位的和:当前位的值等于 l1 的节点值加上 l2 的节点值再加上进位值。
    • 更新进位值 carry:将当前和除以 10 得到的商作为新的进位值。
    • 创建一个新节点,其值为当前和对 10 取余的结果,将该节点连接到结果链表中。
    • 将指针 cur 移动到新节点。
    • 移动 l1 和 l2 指针到下一个节点。
  • 如果遍历结束后还存在进位值 carry,需要再创建一个新节点存储进位值。
  • 返回虚拟头节点 dummy 的下一个节点,即为相加后的链表。

Code:

c 复制代码
class Solution {
public:
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
        ListNode dummy(0);      // 创建一个虚拟头节点
        ListNode* cur = &dummy; // cur 指针指向虚拟头节点
        int carry = 0;          // 进位值初始化为 0

        while (l1 || l2 || carry) {
            int sum = (l1 ? l1->val : 0) + (l2 ? l2->val : 0) + carry;
            carry = sum / 10;                   // 计算进位
            cur->next = new ListNode(sum % 10); // 创建新节点存储当前位的值
            cur = cur->next;

            if (l1)
                l1 = l1->next;
            if (l2)
                l2 = l2->next;
        }

        return dummy.next;
    }
};
相关推荐
不爱吃糖的程序媛几秒前
基于Ascend C开发的Vector算子模板库-ATVOSS 技术深度解读
人工智能·算法·机器学习
松涛和鸣1 分钟前
35、Linux IPC进阶:信号与System V共享内存
linux·运维·服务器·数据库·算法·list
Cx330❀6 分钟前
《C++ 动态规划》第001-002题:第N个泰波拉契数,三步问题
开发语言·c++·算法·动态规划
神仙别闹7 分钟前
基于Qt5(C++)+SQLite 开发的一个小巧精美的本地音乐播放器
开发语言·c++·qt
LYFlied7 分钟前
【每日算法】LeetCode 114. 二叉树展开为链表:从树结构到线性结构的优雅转换
数据结构·算法·leetcode·链表·面试·职场和发展
cheniie9 分钟前
Windows下c/c++使用pgsql
c++·windows·postgresql
毕设源码-钟学长12 分钟前
【开题答辩全过程】以 基于Spark机器学习算法的体育新闻智能分类系统设计与实现为例,包含答辩的问题和答案
算法·机器学习·spark
天勤量化大唯粉14 分钟前
基于距离的配对交易策略:捕捉价差异常偏离的均值回归机会(天勤量化代码实现)
android·开发语言·python·算法·kotlin·开源软件·策略模式
智航GIS15 分钟前
ArcGIS大师之路500技---036通俗易懂讲解克里金法
人工智能·算法·arcgis
Q741_14716 分钟前
Linux 进程核心解析 fork()详解 多进程的创建与回收 C++
linux·c++·面试·笔试·进程