每日一题(LeetCode)----链表--两数相加

每日一题(LeetCode)----链表–两数相加

1.题目(2. 两数相加)

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

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

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

    示例 1:

    img

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

    示例 2:

    输入:l1 = [0], l2 = [0]
    输出:[0]
    

    示例 3:

    输入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
    输出:[8,9,9,9,0,0,0,1]
    

    提示:

    • 每个链表中的节点数在范围 [1, 100]
    • 0 <= Node.val <= 9
    • 题目数据保证列表表示的数字不含前导零

2.解题思路

思路一

循环

1.先获取两个链表的长度,然后把较长链表作为我们的结果链表 2.创建一个记录进位的变量,用两个指针从头开始遍历两个链表每次遍历到的节点如果非空,那么把当前节点中的值和当前进位进行相加,如果和大于10,那么下一次的进位变为1,然后和减10,存到结果链表的对应节点中,一直遍历直到遍历完较长链表时结束,(为了之后我们添加新节点,所以遍历到较长链表的结尾时,我们用tail指针保存一下较长链表的结尾) 3.然后我们查看当前进位是否为0,如果不为零,那我们新创建一个节点,接到结果链表的后面操作结束,如果为零,那么不需要新创建一个节点,操作结束 4.返回新链表的头节点

思路二:递归

递归解法非常巧妙。

做递归题目一定要牢记「递归函数的定义」。

递归函数定义:addTwoNumbers 表示将两个链表 l1 和 l2 相加得到的新链表; 递归终止条件:如果 l1 和 l2 有一个为空,则返回另外一个。 递归函数内容:

把两个链表节点的值相加(结果记为 add )。把 add 模 10 作为当前的链表节点的值。
把两个链表的 next 节点相加。(注意:如果当前相加的结果 add>=10,需要把 next 节点相加得到的结果 + 1。)
递归解法妙在天然地处理好了两个链表不一样长、最终相加结果有进位的情况。

原作者:负雪明烛
链接:https://leetcode.cn/problems/add-two-numbers/

自己的理解:就是先从前到后先走一遍,算出所有的和作为答案,然后从后往前看有哪个和超过了10,超过了10就继续向后递归,但是递归的对象变为当前进位和它的下一位和,到了递归的终止条件之后,就继续向前返回

3.写出代码

思路一的代码
class Solution {
public:ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {//先获取两个链表的长度int length1=0;int length2=0;ListNode* Temp1=l1;ListNode* Temp2=l2;int length=0;while(Temp1){length1++;Temp1=Temp1->next;}while(Temp2){length2++;Temp2=Temp2->next;}//判断那个链表长作为我们的结果链表ListNode* res1=nullptr;ListNode* res2=nullptr;if(length1>=length2){length=length1;res1=l1;res2=l2;}else{length=length2;res1=l2;res2=l1;}Temp1=res1;Temp2=res2;int carry=0;//记录进位的变量ListNode* Temp3=nullptr;//存的是较长链表的最后一个节点//两个链表对应的节点进行相加while(length--){int sum=0;if(Temp1&&Temp2){sum=Temp1->val+Temp2->val+carry;}else{sum=Temp1->val+carry;}carry=0;if(sum>=10){carry++;sum=sum-10;Temp1->val=sum;}else{Temp1->val=sum;}if(Temp1->next==nullptr){Temp3=Temp1;}Temp1=Temp1->next;if(Temp2){Temp2=Temp2->next;}}if(carry>0){ListNode* node=new ListNode(carry);Temp3->next=node;}return res1;}
};
思路二的代码
class Solution {
public:ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {if (!l1) return l2;if (!l2) return l1;int target = l1->val + l2->val;ListNode* res = new ListNode(target % 10);res->next = addTwoNumbers(l1->next, l2->next);if (target >= 10){res->next = addTwoNumbers(res->next, new ListNode(1));}delete l1, l2;return res;}
};
原作者:负雪明烛
链接:https://leetcode.cn/problems/add-two-numbers/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/211955.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JS数组常用的20种方法详解(每一个方法都有例子,超全面,超好理解的教程,干货满满)

目录 1.会改变原数组的方法&#xff08;7种&#xff09; 1.push() 2.pop() 3.unshift() 4.shift() 5.reverse() 6.sort() 7.splice() 2.不改变原数组的方法&#xff08;13种&#xff0c;返回的新数组是从原数组浅拷贝来的&#xff09; 1.concat() 2.join() 3.slice…

231123 刷题日报-动态规划

今天主要看了DP&#xff0c;前几天频繁遇到DP打击有点大。。 1. 0-1背包问题 要点&#xff1a; a. 三部曲&#xff1a; 1. 状态和选择 状态&#xff1a;物品序号、背包容量 选择&#xff1a;放、不放 2. dp数组定义、base case dp[i][w] 对于前i个物品&#xff0c;当前背包…

安卓现代化开发系列——从生命周期到Lifecycle

由于安卓已经诞生快二十载&#xff0c;其最初的开发思想与现代的开发思想已经大相径庭&#xff0c;特别是Jetpack库诞生之后&#xff0c;项目中存在着新老思想混杂的情况&#xff0c;让许多的新手老手都措手不及&#xff0c;项目大步向屎山迈进。为了解决这个问题&#xff0c;开…

【Axure教程】用中继器制作卡片多条件搜索效果

卡片设计通过提供清晰的信息结构、可视化吸引力、易扩展性和强大的交互性&#xff0c;为用户界面设计带来了许多优势&#xff0c;使得用户能够更轻松地浏览、理解和互动。 那今天就教大家如何用中继器制作卡片的模板&#xff0c;以及完成多条件搜索的效果&#xff0c;我们会以…

YOLOv8训练自己的目标检测数据集

YOLOv8训练自己的目标检测数据集 目录标题 源码下载环境配置安装包训练自己的数据集数据集文件格式数据集文件配置超参数文件配置训练数据集命令行训练脚本.py文件训练 进行detect显示detect的效果 源码下载 YOLOv8官方的GitHub代码&#xff0c;同时上面也有基础环境的配置要…

Android——资源IDnonFinalResIds和“Attribute value must be constant”错误

一、异常描述 通过资源ID引用资源提示错误 Attribute value must be constant 二、解决方案 在根目录下的文件 gradle.properties 中添加如下配置&#xff0c;然后Sync Project android.nonFinalResIdsfalse 三、问题原因 android.nonFinalResIds 是Android开发中一个用于解…

3D火山图绘制教程

一边学习&#xff0c;一边总结&#xff0c;一边分享&#xff01; 本期教程内容 **注&#xff1a;**本教程详细内容 Volcano3D绘制3D火山图 一、前言 火山图是做差异分析中最常用到的图形&#xff0c;在前面的推文中&#xff0c;我们也推出了好几期火山图的绘制教程&#xff0…

单链表实现【队列】

目录 队列的概念及其结构 队列的实现 数组队列 链式队列 队列的常见接口的实现 主函数Test.c 头文件&函数声明Queue.h 头文件 函数声明 函数实现Queue.c 初始化QueueInit 创建节点Createnode 空间释放QueueDestroy 入队列QueuePush 出队列QueuePop 队头元…

C++每日选择题—Day1

第一题 以下C代码会输出什么? #include <iostream> using namespace std; class A { public:A() {}~A() {} private:static int a; }; int main() {cout << sizeof(A) << endl;return 0; } A&#xff1a;0 B&#xff1a;1 C&#xff1a;4 D&#xff1a;8 答…

【陈老板赠书活动 - 18期】-如何成为架构师这几本书推荐给你

陈老老老板&#x1f9b8; &#x1f468;‍&#x1f4bb;本文专栏&#xff1a;赠书活动专栏&#xff08;为大家争取的福利&#xff0c;免费送书&#xff09; &#x1f468;‍&#x1f4bb;本文简述&#xff1a;生活就像海洋,只有意志坚强的人,才能到达彼岸。 &#x1f468;‍&am…

微信小程序前端环境搭建

搭建微信小程序前端环境 申请小程序测试账号 访问路径 使用微信扫描二维码进行申请&#xff0c;申请成功之后&#xff0c;进入界面&#xff0c;获取小程序ID(AppID)和秘钥(AppSecret) 安装微信web开发者工具 访问路径 选择稳定开发的版本 需要在小程序的设置中将默认关闭…

微软发布最新.NET 8长期支持版本,云计算、AI应用支持再强化

11 月 15 日开始的为期三天的 .NET Conf 在线活动的开幕日上&#xff0c;.NET 8作为微软的开源跨平台开发平台正式发布。.NET 团队着重强调云、性能、全栈 Blazor、AI 和 .NET MAUI 是.NET 8的主要亮点。.NET团队在 .NET Conf 2023 [1]活动开幕式上表示&#xff1a;“通过这个版…