2.两数相加(传送门)
给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。 请你将两个数相加,并以相同形式返回一个表示和的链表。 你可以假设除了数字 0 之外,这两个数都不会以 0 开头。
因为相同位置的数加起来会涉及到该节点下一个节点数据的改变,
所以我选用集合ArrayList辅助解决问题(有点笨了)
但是还是那句话,自己依靠自己的思路来一遍,会提升我们的编码手感
代码:
public class Solution {
public static ListNode addTwoNumbers(ListNode l1, ListNode l2) {
ListNode head = new ListNode();
ListNode temp = head;
ArrayList<Integer> list1 = new ArrayList<>();
ArrayList<Integer> list2 = new ArrayList<>();
ArrayList<Integer> result = new ArrayList<>();
while (l1 != null) {
list1.add(l1.val);
l1 = l1.next;
}
while (l2 != null) {
list2.add(l2.val);
l2 = l2.next;
}
if (list1.size() > list2.size()) {
int num = list1.size() - list2.size();
for (int i = 0; i < num; i++) {
list2.add(0);
}
}
if (list1.size() < list2.size()) {
int num = list2.size() - list1.size();
for (int i = 0; i < num; i++) {
list1.add(0);
}
}
for (int i = 0; i < list1.size(); i++) {
int sum = list1.get(i) + list2.get(i);
result.add(sum);
}
result.add(0);
for (int i = 0; i < result.size(); i++) {
if (result.get(i) >= 10) {
result.set(i + 1, result.get(i + 1) + 1);
result.set(i, result.get(i) - 10);
}
}
if (result.get(result.size() - 1) == 0) {
result.remove(result.size() - 1);
}
for (Integer integer : result) {
temp.next = new ListNode(integer);
temp = temp.next;
}
return head.next;
}
思考一下,当数据多的情况会产生数组的扩容现象,而扩容会涉及到数据的复制迁移,所以我们是否可以对上述代码进行优化? (尽管测试之后发现并没有表面的提升,但是思想没毛病) 写到这了,就可以看看大佬们的牛逼代码了,我去学学
public static ListNode addTwoNumbers(ListNode l1, ListNode l2) {
ListNode head = new ListNode();
ListNode temp = head;
int size1 = 0;
int size2 = 0;
ListNode temp1 = l1;
ListNode temp2 = l2;
while (temp1 != null) {
temp1 = temp1.next;
size1++;
}
while (temp2 != null) {
temp2 = temp2.next;
size2++;
}
int size = Math.max(size1, size2);
ArrayList<Integer> list1 = new ArrayList<>(size);
ArrayList<Integer> list2 = new ArrayList<>(size);
ArrayList<Integer> result = new ArrayList<>(size + 1);
while (l1 != null) {
list1.add(l1.val);
l1 = l1.next;
}
while (l2 != null) {
list2.add(l2.val);
l2 = l2.next;
}
if (list1.size() > list2.size()) {
int num = list1.size() - list2.size();
for (int i = 0; i < num; i++) {
list2.add(0);
}
}
if (list1.size() < list2.size()) {
int num = list2.size() - list1.size();
for (int i = 0; i < num; i++) {
list1.add(0);
}
}
for (int i = 0; i < list1.size(); i++) {
int sum = list1.get(i) + list2.get(i);
result.add(sum);
}
result.add(0);
for (int i = 0; i < result.size(); i++) {
if (result.get(i) >= 10) {
result.set(i + 1, result.get(i + 1) + 1);
result.set(i, result.get(i) - 10);
}
}
if (result.get(result.size() - 1) == 0) {
result.remove(result.size() - 1);
}
for (Integer integer : result) {
temp.next = new ListNode(integer);
temp = temp.next;
}
return head.next;
}
|