返回介绍

lcof2 / 剑指 Offer II 025. 链表中的两数相加 / README

发布于 2024-06-17 01:04:42 字数 4668 浏览 0 评论 0 收藏 0

剑指 Offer II 025. 链表中的两数相加

题目描述

给定两个 非空链表 l1l2 来代表两个非负整数。数字最高位位于链表开始位置。它们的每个节点只存储一位数字。将这两数相加会返回一个新的链表。

可以假设除了数字 0 之外,这两个数字都不会以零开头。

 

示例1:

输入:l1 = [7,2,4,3], l2 = [5,6,4]
输出:[7,8,0,7]

示例2:

输入:l1 = [2,4,3], l2 = [5,6,4]
输出:[8,0,7]

示例3:

输入:l1 = [0], l2 = [0]
输出:[0]

 

提示:

  • 链表的长度范围为[1, 100]
  • 0 <= node.val <= 9
  • 输入数据保证链表代表的数字无前导 0

 

进阶:如果输入链表不能修改该如何处理?换句话说,不能对列表中的节点进行翻转。

 

注意:本题与主站 445 题相同:https://leetcode.cn/problems/add-two-numbers-ii/

解法

方法一

# Definition for singly-linked list.
# class ListNode:
#   def __init__(self, val=0, next=None):
#     self.val = val
#     self.next = next
class Solution:
  def addTwoNumbers(self, l1: ListNode, l2: ListNode) -> ListNode:
    s1, s2 = [], []
    while l1:
      s1.append(l1.val)
      l1 = l1.next
    while l2:
      s2.append(l2.val)
      l2 = l2.next
    carry, dummy = 0, ListNode()
    while s1 or s2 or carry:
      carry += (0 if not s1 else s1.pop()) + (0 if not s2 else s2.pop())
      # 创建结点,利用头插法将结点插入链表
      node = ListNode(carry % 10, dummy.next)
      dummy.next = node
      carry //= 10
    return dummy.next
/**
 * Definition for singly-linked list.
 * public 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) {
    Deque<Integer> s1 = new ArrayDeque<>();
    Deque<Integer> s2 = new ArrayDeque<>();
    for (; l1 != null; l1 = l1.next) {
      s1.push(l1.val);
    }
    for (; l2 != null; l2 = l2.next) {
      s2.push(l2.val);
    }
    int carry = 0;
    ListNode dummy = new ListNode();
    while (!s1.isEmpty() || !s2.isEmpty() || carry != 0) {
      carry += (s1.isEmpty() ? 0 : s1.pop()) + (s2.isEmpty() ? 0 : s2.pop());
      ListNode node = new ListNode(carry % 10, dummy.next);
      dummy.next = node;
      carry /= 10;
    }
    return dummy.next;
  }
}
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *   int val;
 *   ListNode *next;
 *   ListNode() : val(0), next(nullptr) {}
 *   ListNode(int x) : val(x), next(nullptr) {}
 *   ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
  ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
    stack<int> s1;
    stack<int> s2;
    for (; l1; l1 = l1->next) s1.push(l1->val);
    for (; l2; l2 = l2->next) s2.push(l2->val);
    int carry = 0;
    ListNode* dummy = new ListNode();
    while (!s1.empty() || !s2.empty() || carry) {
      if (!s1.empty()) {
        carry += s1.top();
        s1.pop();
      }
      if (!s2.empty()) {
        carry += s2.top();
        s2.pop();
      }
      ListNode* node = new ListNode(carry % 10, dummy->next);
      dummy->next = node;
      carry /= 10;
    }
    return dummy->next;
  }
};
/**
 * Definition for singly-linked list.
 * type ListNode struct {
 *   Val int
 *   Next *ListNode
 * }
 */
func addTwoNumbers(l1 *ListNode, l2 *ListNode) *ListNode {
  s1, s2 := arraystack.New(), arraystack.New()
  for l1 != nil {
    s1.Push(l1.Val)
    l1 = l1.Next
  }
  for l2 != nil {
    s2.Push(l2.Val)
    l2 = l2.Next
  }
  carry, dummy := 0, new(ListNode)
  for !s1.Empty() || !s2.Empty() || carry > 0 {
    v, ok := s1.Pop()
    if ok {
      carry += v.(int)
    }
    v, ok = s2.Pop()
    if ok {
      carry += v.(int)
    }
    node := &ListNode{Val: carry % 10, Next: dummy.Next}
    dummy.Next = node
    carry /= 10
  }
  return dummy.Next
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文