LeetCode 题号02: 两数相加
Posted Dream_it_possible!
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode 题号02: 两数相加相关的知识,希望对你有一定的参考价值。
目录
leetCode连接:https://leetcode-cn.com/problems/add-two-numbers
一、题目描述
给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。
请你将两个数相加,并以相同形式返回一个表示和的链表。
你可以假设除了数字 0 之外,这两个数都不会以 0 开头。
输入:l1 = [2,4,3], l2 = [5,6,4]
输出:[7,0,8]
解释:342 + 465 = 807.
示例 2:
输入:l1 = [0], l2 = [0]
输出:[0]
示例 3:
输入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
输出:[8,9,9,9,0,0,0,1]
二、解决思路
1) 采用递归思想求解。
2) 维护一个主链表,我在此题中用的是l1作为主链表,将求得的和放在该链表上。
3) 考虑进位,如果2数和大于10或者是/10 大于0,就算进位,进位的话需要将当前的值-10,然后将一次递归的节点+1。
4) 同步链表的长度,保持两个链表的长度一致,因为两个链表的长度可能会不等,那么递归的复杂度就上升。
5) 递归的出口。 递归的出口是在两个链表都遍历到null时,进行退出,每次递归时传的是l1.next和l2.next, 然后将l1的结果返回赋值给l1.next, 递归结束后,得到的l1即为result。
三、完整代码
package leetcode100;
/**
* @Desc:
* @Author: bingbing
* @Date: 2022/4/23 0023 16:04
* https://leetcode-cn.com/problems/add-two-numbers/
* 给你两个非空 的链表,表示两个非负的整数。它们每位数字都是按照逆序的方式存储的,并且每个节点只能存储一位数字。
* <p>
* 请你将两个数相加,并以相同形式返回一个表示和的链表。
* <p>
* 你可以假设除了数字 0 之外,这两个数都不会以 0开头。
* <p>
* 输入:l1 = [2,4,3], l2 = [5,6,4]
* 输出:[7,0,8]
* 解释:342 + 465 = 807.
* 示例 2:
* <p>
* 输入:l1 = [0], l2 = [0]
* 输出:[0]
* 示例 3:
* <p>
* 输入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
* 输出:[8,9,9,9,0,0,0,1]
*
* <p>
* 提示:
* <p>
* 每个链表中的节点数在范围 [1, 100] 内
* 0 <= Node.val <= 9
* 题目数据保证列表表示的数字不含前导零
*
* <p>
* <p>
* 来源:力扣(LeetCode)
* 链接:https://leetcode-cn.com/problems/add-two-numbers
* 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
*/
public class ListNodeSumAdd02
static class ListNode
ListNode next;
Object val;
public ListNode(Object val, ListNode next)
this.next = next;
this.val = val;
public ListNode(Object val)
this.val = val;
@Override
public String toString()
// 遍历链表
return this.val + "->" + (this.next == null ? "NULL" : this.next.toString());
public static ListNode addTwoNumbers(ListNode l1, ListNode l2)
// 以 l1 链表为主链表
if (l1 == null && l2 == null)
return null;
if (l1 == null)
l1 = new ListNode(0, null);
if (l2 == null)
l2 = new ListNode(0, null);
int l1Value = (int) l1.val;
int l2Value = (int) l2.val;
int sum = l1Value + l2Value;
int targetValue;
boolean carry = false;
if (sum >= 10)
targetValue = sum - 10;
carry = true;
else
targetValue = sum;
l1.val = targetValue;
ListNode result;
if (carry)
// 如果进位了,那么就l1.next+1进行递归
if (l1.next == null)
l1.next = new ListNode(0, null);
l1.next.val = (int) l1.next.val + 1;
result = addTwoNumbers(l1.next, l2.next);
if (result == null)
result = new ListNode(1, null);
l1.next = result;
else
l1.next = addTwoNumbers(l1.next, l2.next);
return l1;
public static void main(String[] args)
//l1 = [0,7,5,3,4], l2 = [7,3,4,null] 输出结果:7->0->0->->4->4->null
// ListNode l1 = new ListNode(new ListNode(new ListNode(new ListNode(new ListNode(null, 4), 3), 5), 7), 0);
// ListNode l2 = new ListNode(new ListNode(new ListNode(null, 4), 3), 7);
//9 9 9 9 9
//9 9 9
//8 9 9 0 0 1 null
ListNode l2 = new ListNode(5, new ListNode(6, new ListNode(4, new ListNode(9, null))));
ListNode l1 = new ListNode(2, new ListNode(4, new ListNode(9, null)));
ListNode result = addTwoNumbers(l1, l2);
System.out.println(result);
打印结果:
将方法贴到leetcode里,执行 :
时间和空间复杂度都为0(n)。
以上是关于LeetCode 题号02: 两数相加的主要内容,如果未能解决你的问题,请参考以下文章