-9 逆序输出一个整数的各位数字_求和:两个非空链表表示的整数相加

我准备了 1000 本电子书和计算机各领域高清思维导图 100 张,关注后回复【资源】,即可获取!更可回复【内推】加入 BAT 内推群!

a268607728fc591c266db7cdbd9c387b.gif

01、题目示例

各数据结构中的“加减乘除”都是很爱考察的内容。

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

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

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

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

示例:

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

02、算法图解

烧饼(哨兵)节点:烧饼节点就是说有一个节点长的像烧饼,站在最前面。往往第一个节点小子都会来啃一口,因为是牛肉拔丝烧饼,扯不掉就连起来了。。。好了,我实在编不下去了~囧....

不了解哨兵节点的可以看下:

一支穿云箭,用哨兵节点删除链表倒N节点!

好了,了解了哨兵节点,其实这道题和哨兵节点**并没有什么毛线关系,**我只是让你复习一下(会不会想打我)。现在开始正式分析题目。

老样子,我们还是先画图,假若我们的链表是 (2 -> 4 -> 3) + (5 -> 6 -> 4) ,大概就是这样(注意,这里我们其实是要完成 342 + 465):

6fedd81086e546c6e7689f680f05d6e3.png

加法肯定是从最低位到最高位进行相加,也就是这里的链表头到链表尾进行相加,所以需要遍历链表。我们令 l1 和 l2 指向两个链表的头,用一个 tmp 值来存储同一位相加的结果,以及一个新的链表来存储 tmp 的值。(为什么不直接用新链表存储结果,而是用 tmp 先存储结果,再用新链表存储 tmp 的值呢?请继续往下看)

8094f3fc496935268c614dc22eea4af4.png

记住:所有模拟运算的题目,都需要考虑进位。这里因为个位不涉及进位,开始计算十位。我们同时遍历 l1,l2,以及新链表到下一位。

20fe18b03bb7fb70c0a5542bb721ad93.png

重复上面的操作,可以看到十位与个位不同,发生了进位。这时,刚才的 tmp 就有了用武之地。我们使用 tmp 携带进位的值到下一位的运算。自然,这里的链表也不能直接存储 tmp 的值了,而是要存储 tmp%10 的值。重复这个步骤,直到两个链表都遍历完成,并且 tmp 没有进位值

78a86c4b85db30e1cd815bedb75e6f50.png

现在只需要返回我们的新链表就可以了。问题来了,因为我们没有构造哨兵节点,所以此时不太容易直接返回新链表。所以在整个流程的第一步,我们还需要用一个哨兵节点指向我们的新链表。

92dd1e7ea46a72b33ae22b228473a469.png

分析完毕,直接上代码,go:

//go
func addTwoNumbers(l1 *ListNode, l2 *ListNode) *ListNode {
 list := &ListNode{0, nil}
    //这里用一个result,只是为了后面返回节点方便,并无他用
 result := list
 tmp := 0
 for l1 != nil || l2 != nil || tmp != 0 {
  if l1 != nil {
   tmp += l1.Val
   l1 = l1.Next
  }
  if l2 != nil {
   tmp += l2.Val
   l2 = l2.Next
  }
  list.Next = &ListNode{tmp % 10, nil}
  tmp = tmp / 10
  list = list.Next
 }
 return result.Next
}

执行结果:

09ac9423aa5e7296588df321f8ce2e5e.png

java:

class Solution {
    public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
        ListNode listNode = new ListNode(0);

        ListNode result = listNode;
        int tmp = 0;
        
        while (l1 != null || l2 != null || tmp != 0) {
            if (l1 != null) {
                tmp += l1.val;
                l1 = l1.next;
            }
            if (l2 != null)  {
                tmp += l2.val;
                l2 = l2.next;
            }
            listNode.next = new ListNode(tmp % 10); 
            tmp = tmp / 10;
            listNode = listNode.next;
        }
        return result.next;
    }
}

执行结果:

23f309a1a8493600bd386b0443885046.png
869feba7a8179dc5ba7369713b367704.png 6b08d110b0a994f36abdfe4d8b68c93a.png 50cb830c3c447c140c0b0caa8c1e432f.png

我们欢迎你!

我把我写的所有题解、以及一百张思维导图和一千本开源电子书都放在了公众号中~下方扫码回复【资源】即可获取!同时可回复【招聘】加入 BAT 万人求职群!

7f3a2c348ddfa0969e3545132c665fa7.png

随意展示一张导图内容(所有的子节点都可以打开):

8fde60899eea7d0d450b8ea4129931d2.png

5ad3d5072c6022efa6d756440d83c2e8.png 今日论点:

程序员真的难以交流吗?

12b719e9f39dfebf316f00ac67607779.png

“亲爱的,你能去商店买些牛奶吗?检查他们是否有鸡蛋,然后买2个。” 程序员带着两杯牛奶回家。

段子来源于生活,计算机执行的是精准的指令,严密的逻辑,如果有错,一定是人的逻辑错了。

习惯了与计算机的这种交流方式,遇到没逻辑的人,自然没耐心交流了。

大家怎么看呢?评论区留下你的想法吧!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值