LeetCode2. 两数相加(链表求和)Java实现及思路详解
1、题目描述
两数相加 题目链接: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、解题思路
- 笨办法:遍历两个链表转换为数字,将数字之和再转换成链表,但是太复杂,不推荐
- 从链表的头部开始相加,新建一个链表,新建链表的每一个节点存放对应节点和与进位值之和的个位值。比如示例图中,新建链表第一个节点存放原链表第一个节点 2 与 5 的和 7 ,第二个节点存放原链表第二个节点 4 和 6 的和与进位 0 的和(10)的个位 0,以此类推,直到两个链表都走到尽头且进位为 0,得到新的链表。 时间复杂度为O(max(m+n))
3、Java实现
链表节点直接相加:
//链表节点类
class ListNode {
int val;
ListNode next;
ListNode() {
}
ListNode(int val) {
this.val = val;
}
ListNode(int val, ListNode next) {
this.val = val;
this.next = next;
}
}
class Solution {
public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
//新生成链表的头节点
ListNode node = new ListNode(0);
ListNode root = node;
//临时变量,代表进位
int temp = 0;
//当两个链表遍历完毕且无进位时循环结束
while (l1 != null || l2 != null || temp != 0) {
//取出当前参数节点的值
int l1Val = l1 != null ? l1.val : 0;
int l2Val = l2 != null ? l2.val : 0;
//构建新链表当前节点的下一节点
node.next = new ListNode((temp + l1Val + l2Val) % 10);
node = node.next;
//更新进位
temp = (l1Val + l2Val + temp) / 10;
//参数链表指针后移
if (l1 != null) l1 = l1.next;
if (l2 != null) l2 = l2.next;
}
return root.next;
}
}
