当前位置: 首页 > article >正文

02.05、链表求和

02.05、[中等] 链表求和

1、题目描述

给定两个用链表表示的整数,每个节点包含一个数位。

这些数位是反向存放的,也就是个位排在链表首部。

编写函数对这两个整数求和,并用链表形式返回结果。

2、解题思路

本题要求对两个链表表示的整数进行相加。链表中的每个节点代表一个数位,且个位数在链表的头部。即,链表是以反向存放的方式表示整数的。我们需要编写一个函数来求这两个整数的和,并将结果以链表的形式返回。

  1. 初始化链表和指针:
    • 使用一个虚拟头节点 head 来简化链表操作。
    • cur 用于遍历和构建新链表。
    • cur1cur2 分别用于遍历链表 l1l2
    • add 用于记录当前位的加和及进位。
  2. 遍历链表:
    • 遍历 l1l2,对对应位的数字进行加和。
    • 处理进位情况(即当前位的和超过 10 时的进位)。
  3. 创建新节点:
    • 将当前位的和取个位数,作为新节点的值。
    • 更新进位值(即当前位和除以 10 的结果)。
  4. 处理剩余进位:
    • 如果处理完所有节点后还有进位,需在结果链表中添加一个新节点。
  5. 返回结果:
    • 返回虚拟头节点 head 的下一个节点,即实际结果链表的头节点。

3、代码实现与详细注释

class Solution {
public:
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
        ListNode head; // 虚拟头节点,简化链表操作
        ListNode *cur = &head; // 当前节点,用于构建结果链表
        ListNode *cur1 = l1; // 遍历链表 l1
        ListNode *cur2 = l2; // 遍历链表 l2
        int add = 0; // 存储当前位的和及进位

        // 遍历链表,直到 l1、l2 都为空且没有进位
        while (cur1 || cur2 || add) {
            if (cur1) {
                add += cur1->val; // 加上 l1 当前节点的值
                cur1 = cur1->next; // 移动到 l1 的下一个节点
            }
            if (cur2) {
                add += cur2->val; // 加上 l2 当前节点的值
                cur2 = cur2->next; // 移动到 l2 的下一个节点
            }

            // 创建新节点,存储当前位的和的个位数
            ListNode* newnode = new ListNode(add % 10);
            cur->next = newnode; // 将新节点链接到结果链表
            cur = cur->next; // 移动到结果链表的下一个节点
            add /= 10; // 更新进位值
        }

        return head.next; // 返回结果链表的头节点(跳过虚拟头节点)
    }
};

4、关键点总结

  1. 链表的遍历:
    • 使用 cur1cur2 遍历两个输入链表。
    • 每次从两个链表中取值并加和,处理进位情况。
  2. 进位处理:
    • 在加和过程中,处理进位并更新 add 的值。
    • 如果存在剩余进位,继续在结果链表中添加节点。
  3. 结果链表的构建:
    • 使用虚拟头节点来简化链表的处理。
    • 最终返回虚拟头节点的下一个节点,即实际结果链表的头节点。

5、时间复杂度与空间复杂度

  • 时间复杂度: O(max(m, n)),其中 mn 分别是链表 l1l2 的长度。我们只遍历了两个链表一次。
  • 空间复杂度: O(max(m, n)),因为链表的长度决定了结果链表的长度。

http://www.kler.cn/news/363649.html

相关文章:

  • Android GPU Inspector分析帧数据快速入门
  • MoCoOp: Mixture of Prompt Learning for Vision Language Models
  • 数据导入导出
  • AI修图太牛了! | 换模特、换服装、换背景都如此简单!
  • 不同企业规模,外贸财务系统如何灵活应对
  • 鼠标移入盒子,盒子跟随鼠标移动
  • 【状态机DP】力扣2786. 访问数组中的位置使分数最大
  • 【大模型】3分钟了解提示(Prompt)工程、检索增强(RAG)和微调
  • 前端埋点(tracking)实现多种方式
  • Electron-(三)网页报错处理与请求监听
  • html小游戏-飞机大战
  • 1024感悟 → 勋章
  • Java项目-基于springboot框架的原创歌曲分享系统项目实战(附源码+文档)
  • 人工智能+医学
  • 【C++篇】C++类与对象深度解析(五):友元机制、内部类与匿名对象的讲解
  • 预训练模型通过 prompt(提示)生成的“软标签”是什么
  • C#从零开始学习(封装(5)
  • JAVA Maven 的安装与配置
  • redis 使用
  • 04. VSCODE:C/C++简捷项目专用配置
  • MMA: Multi-Modal Adapter for Vision-Language Models
  • 第1节 什么是鸿蒙系统
  • 基于匿名管道实现的进程池
  • 系统移植相关概念总结
  • 大数据-MySQL集群
  • 使用electron 打包构建cocosCreator 的window exe