两个 非空 的链表按位相加

给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。 请你将两个数相加,并以相同形式返回一个表示和的链表。 你可以假设除了数字 0 之外,这两个数都不会以 0 开头。

示例 1:
输入: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]
def addTwoNumbers(l1, l2):
  """
  :type l1: ListNode
  :type l2: ListNode
  :rtype: ListNode
  """
  carry = 0
  dummy = ListNode(0)
  cur = dummy
  while l1 or l2 or carry:
    val1 = l1.val if l1 else 0
    val2 = l2.val if l2 else 0
    sum = val1 + val2 + carry
    carry = sum // 10
    cur.next = ListNode(sum % 10)
    cur = cur.next
    l1 = l1.next if

class Solution {
public:
  ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
    // 创建虚拟头节点
    ListNode* dummy = new ListNode(0);
    // 当前节点
    ListNode* cur = dummy;
    // 进位
    int carry = 0;
    // 遍历两个链表
    while (l1 || l2 || carry) {
      // 获取两个链表当前节点的值
      int val1 = l1 ? l1->val : 0;
      int val2 = l2 ? l2->val : 0;
      // 计算当前节点的和
      int sum = val1 + val2 + carry;
      // 更新进位
      carry = sum / 10;
      // 创建新的节点并添加到结果链表中
      cur->next = new ListNode(sum % 10);
      // 更新当前节点
      cur = cur->next;
      // 移动两个链表的指针
      l1 = l1 ? l1->next : nullptr;
      l2 = l2 ? l2->next : nullptr;
    }
    // 返回虚拟头节点的下一个节点
    return dummy->next;
  }
};

你可能感兴趣的:(python,C++,算法,链表,数据结构)