【问题标题】:Leetcode: Adding two numbers represented in reverse linked list is not workingLeetcode:添加反向链表中表示的两个数字不起作用
【发布时间】:2018-10-25 19:05:39
【问题描述】:

以下代码不适用于以下输入: [2,4,3] [5,6,4] 输出: [7,8] 预期的: [7,0,8]

为什么我没有得到 0?谁能帮帮我。

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     public int val;
 *     public ListNode next;
 *     public ListNode(int x) { val = x; }
 * }
 */
public class Solution {
    public ListNode AddTwoNumbers(ListNode l1, ListNode l2) {
        return AddTwoNumbersHelper(l1, l2, 0);            
    }


private ListNode AddTwoNumbersHelper(ListNode l1, ListNode l2, int carry) {
    if (l1 == null && l2 == null)
        return null;

    int temp = 0;
    if (l1 != null)
        temp += l1.val;

    if (l2 != null)
        temp += l2.val;

    ListNode result = new ListNode(temp % 10);
    carry = temp / 10;

    l1 = l1.next;
    l2 = l2.next;
    int sum = 0;
    while(l1 != null || l2 != null) {
        sum = carry;

        if (l1 != null)
            sum += l1.val;

        if (l2 != null)
            sum += l2.val;

        carry = sum == 0 ? 0 : sum / 10;
        sum = sum % 10;

        result.next = new ListNode(sum);
        if(l1 != null)
            l1 = l1.next;
        if(l2 != null)
            l2 = l2.next;
    }

    if (carry > 0)
        result.next = new ListNode(carry);

    return result;
} 

}

【问题讨论】:

  • 您一直在覆盖 result.next,您需要保留对第一个结果的引用,然后在循环中添加 result = result.next
  • 非常感谢!它就像一个魅力。
  • 请不要在 cmets 中回答问题。
  • 他不是在回答,而是在不直接告诉我答案的情况下帮助我,这样更好!
  • 如果是这种情况(我同意),那么它也违背了 SO 也有部分用于发布答案的目的。它可以为每个问题启用comments

标签: c# algorithm data-structures linked-list singly-linked-list


【解决方案1】:

代码的一些缺陷:

  1. 您的方法中不需要进位参数,除非您正在递归,但您不需要。
  2. 列表推进步骤 (l = l.next) 可以与将节点值添加到 temp (sum) 变量的步骤结合使用。
  3. 您不需要编写额外的代码来处理悬空提箱,循环就足够了,只需在循环中包含条件即可。
  4. 该错误是因为您不断更新头部的下一个指针,而不是在每次迭代中构建(添加一个节点)到链表。你需要一个额外的指针/变量来做到这一点。
  5. 'sum' 在这里是一个比'temp' 更好的变量名。

这是一个稍微修改的解决方案,可以解决上述问题:

private ListNode AddTwoNumbersHelper(ListNode l1, ListNode l2) {

    ListNode result = null;
    ListNode tail = null;
    int carry = 0;
    while ((l1 != null) || (l2 != null) || (carry != 0)) {

        int sum = carry;
        if (l1 != null) {
            sum += l1.val;
            l1 = l1.next;
        }
        if (l2 != null) {
            sum += l2.val;
            l2 = l2.next;
        }
        carry = sum/10;
        sum %= 10;
        if (result == null) { // first time
            result = new ListNode(sum);
            tail = result;
        } else {
            tail.next = new ListNode(sum);
            tail = tail.next;
        }
    }
    return result;
}

【讨论】:

    猜你喜欢
    • 2021-08-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-04-16
    • 1970-01-01
    • 2020-04-07
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多