LeetCode算法题:2. 两数相加

文章目录


题目描述:

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

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

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

题目链接:2. 两数相加


通过代码

创建新一串新链表:

优点是便于思考操作,但是会增加存储空间的占用,如果链表内的数据本身就很大,就会加剧内存的消耗

cpp 复制代码
/**
 * 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 *first=new ListNode();
        ListNode* p=first,*p1=l1,*p2=l2;
        while(p1||p2){
            if(p1){p->val+=p1->val;p1=p1->next;}
            if(p2){p->val+=p2->val;p2=p2->next;}
            if(p1||p2||p->val>9){
                p->next=new ListNode();
                if(p->val>9){
                    p->val-=10; 
                    p->next->val=1;
                }
                p=p->next;
            }
        }
        return first;
    }
};

至此,结束

相关推荐
Wadli1 分钟前
26.单调栈
算法
xian_wwq1 分钟前
【学习笔记】网络与数据安全领域强制性标准
笔记·学习
晨曦夜月3 分钟前
进程的五大状态及特殊进程解析
linux·服务器·算法
24白菜头6 分钟前
【无标题】
c++·笔记·学习·harmonyos
吟安安安安7 分钟前
适合短期冲刺的学习工作流(针对算法)
学习·算法
科研前沿12 分钟前
什么是时空融合技术?
大数据·人工智能·数码相机·算法·重构·空间计算
AI科技星17 分钟前
全域数学本源公理:0、1、∞ 三者核心关系 (典籍定稿版)
人工智能·算法·数学建模·数据挖掘·量子计算
suirosu20 分钟前
痛风高尿酸血症的治疗方法
笔记·其他·微信·新浪微博
AI科技星22 分钟前
全域数学·第卷:场计算机卷(场空间计算机)【乖乖数学】
java·开发语言·人工智能·算法·机器学习·数学建模·数据挖掘
Deepoch23 分钟前
数学模型驱动:Deepoc 低幻觉数学大模型助力发动机全周期智能优化
人工智能·算法·机器学习·deepoc·数学大模型·低幻觉