专栏首页InvQ的专栏走访 Linked List 时考虑进位

走访 Linked List 时考虑进位

给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。

如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。

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

示例:

输入:(2 -> 4 -> 3) + (5 -> 6 -> 4) 输出:7 -> 0 -> 8 原因:342 + 465 = 807

solution recommend (神奇的pre指针)

public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
     ListNode pre = new ListNode(0);
        ListNode cur = pre;
        int carry = 0;
        while (l1 != null || l2 != null) {
            int x = l1 == null ? 0 : l1.val;
            int y = l2 == null ? 0 : l2.val;
            int sum = x + y + carry;

            carry = sum / 10;
            sum = sum % 10;
            cur.next = new ListNode(sum);

            cur = cur.next;
            if (l1 != null)
                l1 = l1.next;
            if (l2 != null)
                l2 = l2.next;
        }
        if (carry == 1) {
            cur.next = new ListNode(carry);
        }
        return pre.next;
     }

solution other

尝试偷懒,用最简单的逻辑,计算完然后给到listnode中,但是平台不允许,所以pass。

 StringBuilder s1 = new StringBuilder();
        StringBuilder s2 = new StringBuilder();
        s1.append(l1.val);
        s2.append(l2.val);
        ListNode next1 = l1.next;
        ListNode next2 = l2.next;
        while (next1 != null) {
            s1.append(next1.val);
            next1 = next1.next;
        }
        while (next2 != null) {
            s2.append(next2.val);
            next2 = next2.next;
        }
        BigDecimal a = new BigDecimal(s1.reverse().toString());
        BigDecimal b = new BigDecimal(s2.reverse().toString());
        BigDecimal addResult = a.add(b);
        String s3 = new StringBuilder(String.valueOf(addResult)).reverse().toString();
        char[] array = s3.toCharArray();
        List<ListNode> listNodes = new ArrayList<>();
        for (char s : array) {
            listNodes.add(new ListNode(Integer.parseInt(Character.toString(s))));
        }
        int size = listNodes.size();
        if (size > 0) {
            for (int i = 0; i < size - 1; i++) {
                listNodes.get(i).next = listNodes.get(i + 1);
            }
            return listNodes.get(0);
        }
        return new ListNode(0);
    }

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • java字符串操作:如何实现字符串的反转及替换?

    可用字符串构造一 StringBuffer 对象,然后调用 StringBuffer 中的 reverse

    MickyInvQ
  • Spring的BeanUtil的copyProperties方法 慎用!!

    笔者在用工作场景中发现代码中一个bug,有两批对象,A批和B批,发现对B批没有进行什么操作,但是对象的内容变化了。

    MickyInvQ
  • 什么是Javac

    Javac 编译器的任务就是讲java语言规范转化成Java虚拟机语言规范,完成 “翻译工作”

    MickyInvQ
  • leetcode刷题: 002 Add Two Numbers

    You are given two linked lists representing two non-negative numbers. The digits...

    用户7043923
  • LeetCode97|合并两个有序链表

    这道题理解起来还是比较容易的对吧,两两比较,然后将较小的数据挂载dummyNode节点后面,这就是使用哨兵节点的好处,一般链表都或多或少的增加一个哨兵节点来处理...

    码农王同学
  • LeetCode16|两数相加

    给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。

    码农王同学
  • 剑指Offer LeetCode 面试题25. 合并两个排序的链表

    输入:1->2->4, 1->3->4 输出:1->1->2->3->4->4 限制:

    TrueDei
  • 两数相加

    给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。

    OPice
  • LeetCode - 002

    https://leetcode.com/problems/add-two-numbers/description/

    咸鱼学Python
  • C++版 - 剑指offer之面试题37:两个链表的第一个公共结点[LeetCode 160] 解题报告

    提交网址: http://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46?tpId=13&...

    Enjoy233

扫码关注云+社区

领取腾讯云代金券