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

【算法】链表:2.两数相加(medium)+模拟

 系列专栏

《分治》

《模拟》

《Linux》


目录

1、题目链接 

2、题目介绍

3、解法 (模拟)

4、代码


 

1、题目链接 

2. 两数相加 - 力扣(LeetCode)

2、题目介绍

3、解法 (模拟)

  1. 理解题目要求
    • 我们有两个链表,每个链表代表一个逆序存储的非负整数。
    • 我们需要将这两个数相加,并以相同的形式(逆序链表)返回结果。
  2. 初始化
    • 创建两个指针 cur1 和 cur2 分别指向两个链表的头节点。
    • 创建一个新的链表 l3 来存储结果,并且为了方便操作,我们使用一个哑节点 dummy,其 next 指向 l3。哑节点的作用是方便处理边界情况,最后返回结果时只需返回 dummy->next
    • 初始化一个变量 num 来保存进位值,初始为 0。
  3. 遍历链表
    • 使用一个 while 循环来遍历两个链表,条件是 cur1 或 cur2 不为空,或者 num(进位值)不为 0。
    • 在每次循环中,如果 cur1 为空,则将 a 设为 0;如果 cur2 为空,则将 b 设为 0。这样做是为了处理链表长度不一致的情况。
    • 计算当前位的和 sum = a + b + num
  4. 处理进位和创建新节点
    • 计算新的进位值 num = sum / 10
    • 计算当前位的值 sum %= 10,这是实际要添加到结果链表中的值。
    • 在 l3 后面创建一个新节点,其值为 sum,然后移动 l3 指针到这个新节点。
  5. 移动指针
    • 如果 cur1 不为空,将其移动到下一个节点。
    • 如果 cur2 不为空,将其移动到下一个节点。
  6. 返回结果
    • 循环结束后,返回 dummy->next,即跳过了哑节点,返回的是实际存储结果的链表的头节点。

这种方法的时间复杂度是 O(max(m, n)),其中 m 和 n 分别是两个链表的长度,因为我们最多遍历两个链表各一次。空间复杂度是 O(max(m, n)),因为我们需要创建一个新的链表来存储结果,其长度最多与较长的链表相同。

4、代码

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */


class Solution {
public:
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
        //两个链表肯定不为空
        ListNode* cur1 = l1;
        ListNode* cur2 = l2;
        
        ListNode* l3 = new ListNode(0);//新链表,创建一个头节点
        ListNode* dummy = l3;
        int num = 0;
        while (cur1 != NULL || cur2 != NULL || num)    //需要考虑进位,加到最后,有进位还需要进一步创建新的节点
        {
            int sum = 0;//每位上的求和
            int a = cur1 == nullptr ? 0 : cur1->val;
            int b = cur2 == nullptr ? 0 : cur2->val;
            sum = a + b + num;//加上,上一次和的进位(0/1)

            //处理进位
            num = sum / 10;
            sum %= 10;//无论是否进位,%都不影响结果
            //添加元素
            l3->next = new ListNode(sum);
            l3 = l3->next;

            if(cur2!=NULL)cur2 = cur2->next;
            if (cur1 != NULL)cur1 = cur1->next;
        }
        return dummy->next;

    }
};


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

相关文章:

  • 自然语言处理问答系统最全内容--你值得一看
  • Java 的数据结构整理(整合版)
  • 甲虫身体图像分割系统源码&数据集分享
  • PostgreSQL学习笔记五:数据库基本操作
  • windows系统下Nginx负载均衡实战总结
  • SQL优化 where谓词条件OR优化
  • Android开发视频预览效果
  • 强制删除了windows自带的edge浏览器,重装不了怎么办【已解决】
  • 机器学习笔记(四)-决策树
  • 斯坦福UE4 C++课学习补充25:AI感知组件
  • 51单片机-第十四节-AD/DA(XPT2046触摸屏)
  • 【学术会议征稿】2024年信号处理与神经网络应用国际学术会议(SPNNA 2024)
  • OpenCVSharp使用MeanShift图像分割详解
  • 【STM32-HAL库】实现微秒、毫秒、纳秒延时。(STM32F4系列)(附带工程下载链接)
  • 贪心算法:原理、应用与优化
  • Python OpenCV精讲系列 - 实例分割深入理解(十八)
  • 【devops】x-ui 实现一键安装 x-ray 打造高速国际冲浪 | xray管理平台
  • C# 类型增加自定义xml序列化
  • 【gRPC】1—gRPC是什么
  • Python中的with关键字和文件操作