[链表专题]两数相加

描述

本题是力扣的2. 两数相加

考点

  • 链表的合并

题解

class Solution {
 public:
  int carry = 0;
  ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
   ListNode *cur1 = l1, *cur2 = l2, *dummyHead = new ListNode(-1), *curNew = dummyHead;
   while (cur1 != nullptr || cur2 != nullptr || carry) {
    cur1 = cur1 != nullptr ? (carry += cur1->val, cur1->next) : nullptr;
    cur2 = cur2 != nullptr ? (carry += cur2->val, cur2->next) : nullptr;
    curNew->next = new ListNode(carry % 10);
    carry /= 10;
    curNew = curNew->next;
   }
   return dummyHead->next;
  }
};

思路

题目要我们算两个数相加的结果,146+854=1000;但要求的存储方式是倒过来的,641+458=0001

思路很简单:

  • 每次计算cur1+cur2+进位的和,将和求余10的值赋给新建的链表节点,将和除10的值更新进位

  • 只要cur1、cur2、进位有一个不为空,就要重复上述操作新增链表节点

若要将其改造成递归就稍有难度

  1. 子问题:计算步骤同上;还需要将每次新增的链表节点串起来

  2. 递归语句顺序:递归方向分为一去一回,去方向到达临界点后返回

    在这里,先在去方向构造完新链表节点;在回方向更新当前节点的next值,从而将链表串起来

  3. 返回值:因为只能在回方向将新链表串起,所以每次返回新节点让上一个节点更改它的next

  4. 临界点:cur1、cur2、进位都为空

class Solution {
 public:
  int carry = 0;
  ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
   if (l1 == nullptr && l2 == nullptr && !carry) return nullptr;
   l1 = l1 != nullptr ? (carry += l1->val, l1->next) : nullptr;
   l2 = l2 != nullptr ? (carry += l2->val, l2->next) : nullptr;
   ListNode *head = new ListNode(carry % 10);
   carry /= 10;
   head->next = addTwoNumbers(l1, l2);
   return head;
  }
};

如果是99+9,到达临界点的情况如图所示;8、0、1的新建节点并没有串起来,所以才需要回方向将它们连接起来

更多

恭喜你完成本题!

你可以选择继续下一题,或移步至仓库开始更多类型的挑战:https://fi3wey.github.io/

仓库内包含了更多经典案例的逻辑剖析与实现细节,助你在算法的学习之旅上一往无前!

看官若还满意,还请Star一下哟~

关注公众号峰狂算法,获取最新的刷题指导呀~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值