只需要注意一个问题,就是进位的添加和赋零。
class Solution {
public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
// head: 记录链表头,tail:移动指针
ListNode head = null, tail = null;
// 进位:
int carry = 0;
while(l1 != null || l2 != null) {
int n1 = l1 == null ? 0 : l1.val;
int n2 = l2 == null ? 0 : l2.val;
// 加上进位:
int sum = n1 + n2 + carry;
if(head == null) head = tail = new ListNode(sum % 10); // 初始化链表头,只会进入一次
else {
tail.next = new ListNode(sum % 10);
tail = tail.next;
}
// 如果不大于10自动赋值为0
carry = sum / 10;
if(l1 != null) l1 = l1.next;
if(l2 != null) l2 = l2.next;
}
if(carry > 0) tail.next = new ListNode(carry);
return head;
}
}