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

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

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

题目

难度:中级

原题:

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


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

查看所有标签

猜你喜欢:

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

技术领导之路(中英文对照)

技术领导之路(中英文对照)

Gerald M.Weinberg / 余晟 / 电子工业出版社 / 2009-12 / 69.00元

《技术领导之路:全面解决问题的途径(中英文对照)》内容简介:搞定技术问题并不简单,但与人打交到也并非易事。作为一个技术专家,你是否在走上管理岗位时遇到了各种不适“症状”?《技术领导之路:解决问题的有机方法》一书将帮助你成为一个成功的解决问题的领导者。书中温伯格从一个反思者的角度阐述了要成为一个成功的解决问题的领导者必备的3个技能——MOI,即激励(Motivation)、组织(Organizati......一起来看看 《技术领导之路(中英文对照)》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

SHA 加密
SHA 加密

SHA 加密工具