您的位置:首页 > 其它

LeetCode - 两数相加

2018-03-04 16:53 411 查看
题目解析:https://leetcodechina.com/problems/add-two-numbers/description/

https://github.com/biezhihua/LeetCode

核心解析:

1. 链表对应结点相加时增加前一个结点的进位,并保存下一个结点的进位;除法得进位,模得结果。

2. 两个链表长度不一致时,要处理较长链表剩余的高位和进位计算的值;

3. 如果最高位计算时还产生进位,则还需要添加一个额外结点。

最佳解法:

ListNode addTwoNumbers(ListNode l1, ListNode l2) {
ListNode tmp = null;
ListNode result = null;

int carry = 0;
while (l1 != null || l2 != null || carry != 0) {
int sum = (l1 == null ? 0 : l1.val) + (l2 == null ? 0 : l2.val) + carry;
carry = sum / 10;

ListNode node = new ListNode(sum % 10);
if (tmp == null) {
tmp = node;
result = tmp;
} else {
tmp.next = node;
tmp = tmp.next;
}

l1 = l1 == null ? null : l1.next;
l2 = l2 == null ? null : l2.next;
}

return result;
}

public class ListNode {
int val;
ListNode next;

ListNode(int x) {
val = x;
}
}


我的解法:

/**
* https://leetcodechina.com/problems/add-two-numbers/description/ */
public class Code_3_4_AddTwoNumbers {

@Test
public void test() {
ListNode _342 = new ListNode(2);
_342.next = new ListNode(4);
_342.next.next = new ListNode(3);

ListNode _465 = new ListNode(5);
_465.next = new ListNode(6);
_465.next.next = new ListNode(4);

ListNode result = addTwoNumbers(_342, _465);
Assert.assertEquals(7, result.val);
Assert.assertEquals(0, result.next.val);
Assert.assertEquals(8, result.next.next.val);

ListNode result1 = addTwoNumbers(new ListNode(5), new ListNode(5));
Assert.assertEquals(0, result1.val);
Assert.assertEquals(1, result1.next.val);

ListNode _98 = new ListNode(9);
_98.next = new ListNode(8);

ListNode _1 = new ListNode(1);
ListNode result2 = addTwoNumbers(_98, _1);
Assert.assertEquals(0, result2.val);
Assert.assertEquals(9, result2.next.val);
}

ListNode addTwoNumbers(ListNode l1, ListNode l2) {
ListNode tmp = null;
ListNode result = null;

boolean flag = false;

while (l1 != null && l2 != null) {

int cur = l1.val + l2.val + (flag ? 1 : 0);

flag = cur >= 10;

ListNode node = new ListNode(flag ? cur % 10 : cur);
if (tmp == null) {
tmp = node;
result = tmp;
} else {
tmp.next = node;
tmp = tmp.next;
}

l1 = l1.next;
l2 = l2.next;
}

while (l1 != null) {

int cur = l1.val + (flag ? 1 : 0);

flag = cur >= 10;

ListNode node = new ListNode(flag ? cur % 10 : cur);
if (tmp == null) {
tmp = node;
result = tmp;
} else {
tmp.next = node;
tmp = tmp.next;
}

l1 = l1.next;

}

while (l2 != null) {

int cur = l2.val + (flag ? 1 : 0);

flag = cur >= 10;

ListNode node = new ListNode(flag ? cur % 10 : cur);
if (tmp == null) {
tmp = node;
result = tmp;
} else {
tmp.next = node;
tmp = tmp.next;
}
l2 = l2.next;
}

if (flag) {
tmp.next = new ListNode(1);
}

return result;
}

public class ListNode {
int val;
ListNode next;

ListNode(int x) {
val = x;
}
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: