Leetcode 第2题 Add Two Numbers题解 (Java)

栏目: Java · 发布时间: 6年前

内容简介:难度:中级原题:这题的基本意思是,给你两个

题目

难度:中级

原题:

Leetcode 第2题 Add Two Numbers题解 (Java)

这题的基本意思是,给你两个 非空的 链表表示了两个正整数。每一个节点表示一位数字,按照反序(个位数在最前面)。把两个数字加起来,返回一个代表和的链表。

你可以假设这两个数字都不带前导0,除非0这个数字本身。

示例为:

输入:(2 -> 4 -> 3) + (5 -> 6 ->4)

输出:7 ->0 -> 8

解释:342 + 465 = 807

下面是分析和题解:

题目很好理解,而且链表已经反序计算起来并不难,两个数字的位数可能不同,如果高位在前,我们硬从高位算起还需要对齐。从低位算起就很简单。事实上,这跟我们小时候用竖式做加法很像,我们举例如下:

Leetcode 第2题 Add Two Numbers题解 (Java)

如果你还记得小时候学竖式加法,其实就是从最后一位加起,两个数字相加,如果不超过10,结果直接写在结果的位置上,如果超过10则在前面加上一个进位标记。也就是我在图中,4和6之间放的标记。然后如果所在位置已经有进位符号则两个数字相加后,再加一。我们小学就都学习这个了。这不难,其实就是把这个逻辑翻译成代码即可,而且这个题,我想象不出什么加速方法,就这么一位一位的加效率就一定是很高的,其实就是同时遍历两个链表,取出当前位置的数字,相加,如果某一个链表已经穷尽,则直接输出另外一个链表的数字。如果两个链表都穷尽,则运算完成。

现在我们看代码:

Leetcode 第2题 Add Two Numbers题解 (Java)
Leetcode 第2题 Add Two Numbers题解 (Java)

这道题并不难,算不上中间,最多就是Easy。时间复杂度是O(n)。我的提交时间是19ms,在 java 提交中打败了98.07%的提交者。

本文对应的代码在我的Github可以找到 https://github.com/tinyfool/leetcode/tree/master/src/p0002


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

疯狂又脆弱  坚定又柔软

疯狂又脆弱 坚定又柔软

朱墨 / 湖南文艺出版社 / 2018-3 / 39.80元

《疯狂又脆弱 坚定又柔软》是朱墨的一部作品集,介绍了作者考研到北京,工作在华谊,以及留学去英国的经历,在这短短几年中她一路升职加薪,25岁升任华谊宣传总监,27岁赚到人生的第一笔100万,30岁却毅然离职去英国留学,在表面的光鲜亮丽之下,她也曾付出过外人所不知道的心血和努力。她的人生告诉我们,每一个身居高位或者肆意潇洒的人,都曾为梦想疯狂地倾尽全力,而那些心怀梦想的人也总是怀揣一颗坚定又柔软的内心......一起来看看 《疯狂又脆弱 坚定又柔软》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

URL 编码/解码
URL 编码/解码

URL 编码/解码

SHA 加密
SHA 加密

SHA 加密工具