题目:
给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。
请你将两个数相加,并以相同形式返回一个表示和的链表。
你可以假设除了数字 0 之外,这两个数都不会以 0 开头。
输入:l1 = [2,4,3], l2 = [5,6,4]
输出:[7,0,8]
解释:342 + 465 = 807
代码:
class Solution {
public:
ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
ListNode* dummy = new ListNode(0); // 创建一个虚拟头节点作为结果链表的头节点
ListNode* curr = dummy; // 创建一个指针指向当前节点,初始指向虚拟头节点
int carry = 0; // 进位值
while (l1 != nullptr || l2 != nullptr) {
int x = (l1 != nullptr) ? l1->val : 0; // 如果l1不为空,取l1当前节点的值,否则为0
int y = (l2 != nullptr) ? l2->val : 0; // 如果l2不为空,取l2当前节点的值,否则为0
int sum = carry + x + y; // 当前位的和
carry = sum / 10; // 计算进位值
curr->next = new ListNode(sum % 10); // 创建新的节点保存当前位的值
curr = curr->next; // 当前节点指针后移
if (l1 != nullptr) l1 = l1->next; // l1指针后移
if (l2 != nullptr) l2 = l2->next; // l2指针后移
}
if (carry > 0) {
curr->next = new ListNode(carry); // 如果最后一位有进位,创建新的节点保存进位值
}
return dummy->next; // 返回结果链表的头节点
}
};
//2023年6月25日22点38分