【发布时间】: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