-
题目:给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。
请你将两个数相加,并以相同形式返回一个表示和的链表。
你可以假设除了数字 0 之外,这两个数都不会以 0 开头。
来源:力扣(LeetCode) 链接:leetcode-cn.com/problems/ad… 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
Test Case
输入: l1 = [2,4,3], l2 = [5,6,4]
输出: [7,0,8]
解释: 342 + 465 = 807.
-
解题思路:
- 首先找到长链表l 和 短链表s
- 然后在相加的过程中分成 三种情况 长链表存在短链表也存在、短链表遍历结束但是长链表没有遍历结束、长短列表都遍历结束
- 在长短链表都遍历结束的情况下,还有判断是否有没有进位信息,如果有进位信息,需要给它加上进位信息
-
Coding
public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
//分别找到长链表与短的链表
int len1 = listLength(l1);
int len2 = listLength(l2);
ListNode l = len1>len2?l1:l2;
ListNode s = l == l1?l2:l1;
ListNode curL = l;
ListNode curS = s;
ListNode last = curL;
int carry = 0; //表示的是进位信息
int curNum = 0; //计算和
//阶段1 长,短链表存在的情况下
while(curS!=null){
curNum = curL.val + curS.val + carry;
curL.val = curNum%10;
carry = curNum/10;
last = curL;
curL = curL.next;
curS = curS.next;
}
//阶段2,只剩下长链表的情况下
while(curL!=null){
curNum = curL.val + carry;
curL.val = curNum%10;
carry = curNum/10;
last = curL;
curL = curL.next;
}
//阶段3,长短链表都没有情况下,并且有进位
if(carry!=0){
last.next = new ListNode(1);
}
return l;
}