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

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

一、题目解析

1、对逆序存储的数字求和,返回一个同样逆序的链表

2、不会出现先导0的情况

二、算法原理

解法:模拟两数相加的过程

定义一个变量t记录每一位之和,按照两数相加的过程,t=2+5,new 一个ListNode(t%10),这里7%10=7,t/=10进位操作,然后继续进行下去

哨兵位头节点和tail节点

为了避免边界条件的判断和操作遍历,我们会创建一个newhead的哨兵位头节点,该节点并不存储任何有限数据,仅做哨兵标记处理;由于返回逆序结果,我们需要多次对链表进行尾插操作,所以我们定义tail节点用于标记链表中最后一个节点,节约从头遍历找尾的时间

遍历边界条件

由于无法保证两个链表长度一致,所以会出现一个链表遍历完了,但另一个却没有遍历完的情况,需要特殊处理

检查记录每位之和变量t

存在两个链表都遍历完了,但是由于循环条件的设置,导致t中的进位情况没有处理完,所以需要在返回结果之前,检查t是否未0,不未0则需要new ListNode(t),然后接到tail节点的后面,最终返回newhead->next即可,我们返回的逆序和链表不包括哨兵位头节点

对于链表操作模糊的读者可以移步博主的另一篇博客

数据结构之单链表-CSDN博客or带头双向循环单链表-CSDN博客

三、代码示例

class Solution {
public:ListNode* addTwoNumbers(ListNode* l1, ListNode* l2){ListNode* newhead = new ListNode();ListNode* tail = newhead; ListNode* cur1 = l1;ListNode* cur2 = l2;int t = 0;while(cur1!=nullptr||cur2!=nullptr){if(cur1 == nullptr){t+=cur2->val;cur2 = cur2->next;}else if(cur2 == nullptr){t+=cur1->val;cur1 = cur1->next;}else{t+=cur1->val;t+=cur2->val;cur1=cur1->next;cur2=cur2->next;}ListNode* newnode = new ListNode(t%10);t/=10;tail->next = newnode;tail=tail->next;}if(t!=0){ListNode* newnode = new ListNode(t);tail->next = newnode;}return newhead->next;   }
};

看到最后,如果对您有所帮助,还请点赞、收藏和关注,我们下期再见!

http://www.xdnf.cn/news/1326511.html

相关文章:

  • 中科米堆CASAIM自动化三维测量设备测量汽车壳体直径尺寸
  • 丝杆支撑座在自动化生产线中的关键支撑
  • Java -- 用户线程和守护线程--线程同步机制
  • ios使用saveVideoToPhotosAlbum 保存视频失败提示 invalid video
  • oracle官网下载jdk历史版本,jdk历史版本下载
  • 小程序开发APP
  • 应用控制技术、内容审计技术、AAA服务器技术
  • STL——string的使用(快速入门详细)
  • 可靠性测试:软件稳定性的守护者
  • Flink Stream API - 源码二开详细实现
  • 低延迟、跨平台与可控性:直播SDK的模块化价值解析
  • 基于 PyTorch 模型训练优化、FastAPI 跨域配置与 Vue 响应式交互的手写数字识别
  • 微服务架构的演进:从 Spring Cloud Netflix 到云原生新生态
  • 如何在 uBlock Origin 中忽略指定网站的某一个拦截规则
  • 数字孪生 :提高制造生产力的智能方法
  • 当宠物机器人装上「第六感」:Deepoc 具身智能如何重构宠物机器人照看逻辑
  • 常见的软件图片缩放,算法如何选择?
  • 当机器猫遇上具身智能:一款能读懂宠物心思的AI守护者
  • ISIS高级特性
  • 驱动开发系列66 - glCompileShader实现 - GLSL中添加内置函数
  • MySQL练习题50题(附带详细教程)
  • 【GNSS定位原理及算法杂记5】​​​​PPK(后处理动态定位)深度解析:后处理的艺术与 RTK 的互补
  • ListBoxes使得在专为灵活性和易用性设计
  • GaussDB 中 alter default privileges 的使用示例
  • 从数据表到退磁:Ansys Maxwell中N48磁体磁化指南
  • GaussDB 八种常规锁介绍
  • MoonBit Perals Vol.06: Moonbit 与 LLVM 共舞 (上):编译前端实现
  • CloudDM 新增支持 GaussDB 与 openGauss:国产数据库管理更高效
  • wx小游戏canvas能力封装
  • 推理还是训练 || KV缓存和CoT技术