100道面试必会算法-29-两数之和

100道面试必会算法-29-两数之和

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

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

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

img

示例 1:

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

算法思路

  • 我们可以使用一个循环遍历两个输入链表,同时将它们的对应节点的值相加。

  • 在相加过程中,我们需要考虑进位问题,并将进位值存储起来,以便在下一次迭代中使用。

  • 每次迭代得到的结果应该存储在一个新的链表中。

  • 当两个输入链表都遍历完毕后,如果还有剩余的进位,则需要将其作为一个额外的节点添加到结果链表的末尾。

  • 算法实现

    public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
        // 创建一个新的 ListNode 来存储结果,初始值为0
        ListNode pre = new ListNode(0);
        // 初始化指针'cur'指向结果 ListNode
        ListNode cur = pre;
        // 初始化一个变量'last'来存储进位值
        int last = 0;
        // 循环直到两个输入链表都遍历完毕
        while (l1 != null || l2 != null) {
            // 获取当前的 l1 和 l2 的值,如果为 null 则取0
            int x = l1 == null ? 0 : l1.val;
            int y = l2 == null ? 0 : l2.val;
            // 计算当前位数和进位的和
            int sum = x + y + last;
            // 更新下一次迭代的进位值
            last = sum / 10;
            // 创建一个新的 ListNode,值为当前位数和模10的结果
            cur.next = new ListNode(sum % 10);
            // 如果 l1 和 l2 不为 null,则移动到下一个节点
            if (l1 != null) l1 = l1.next;
            if (l2 != null) l2 = l2.next;
            // 移动到结果链表的下一个节点
            cur = cur.next;
        }
        // 如果还有剩余的进位,添加一个值为1的新的 ListNode
        if (last == 1) cur.next = new ListNode(1);
        // 返回初始 ListNode 的下一个节点,即结果的起始节点
        return pre.next;
    }
    
    
    • 创建一个新的 ListNode 作为结果链表的头节点,值为0。
    • 使用一个指针 ‘cur’ 指向结果链表的当前节点,初始化为头节点。
    • 使用一个变量 ‘last’ 来存储进位值,初始值为0。
    • 在一个循环中,遍历两个输入链表,将对应节点的值相加,并考虑进位问题。
    • 将得到的和的个位数作为新的节点值,更新 ‘cur’ 指针指向下一个节点,并更新 ‘last’ 值。
    • 如果两个输入链表都遍历完毕后,还有剩余的进位,则将其作为一个额外的节点添加到结果链表的末尾。
    • 返回结果链表的头节点的下一个节点,即为最终的结果链表
      入链表都遍历完毕后,还有剩余的进位,则将其作为一个额外的节点添加到结果链表的末尾。
    • 返回结果链表的头节点的下一个节点,即为最终的结果链表
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值