- q2 两数相加
给你两个非空的链表,表示两个非负的整数。它们每位数字都是按照逆序的方式存储的,并且每个节点只能存储一位数字。请你将两个数相加,并以相同形式返回一个表示和的链表。
思路:首先逐位相加,节点为空的表示为0,然后用新链表存储两个数的和,逐个检查新链表里面每个数据,大于等于10则减去10,且其next加一,next为空则新建0节点
public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
ListNode rs = new ListNode(l1.val + l2.val);
l1 = l1.next;
l2 = l2.next;
ListNode temp = rs;
//先假设ab都等于0,即两个链表都为空,
while (l1 != null || l2 != null) {
int a = 0;
int b = 0;
if (l1 != null) {
a = l1.val;
}
if (l2 != null) {
b = l2.val;
}
//两者相加并存储,同时判断条件三个链表各自后移
int t = a + b;
temp.next = new ListNode(t);
temp = temp.next;
if (l1 != null) {
l1 = l1.next;
}
if (l2 != null) {
l2 = l2.next;
}
}
temp = rs;
//判断temp上的数值是否大于10,大于10则减去10,下一位加1,下一位为空则新建0节点再加一
while (temp != null) {
if (temp.val >= 10) {
temp.val = temp.val - 10;
if (temp.next == null) {
temp.next = new ListNode(0);
}
temp.next.val = temp.next.val + 1;
}
temp = temp.next;
}
return rs;
}
- q19 删除倒数第N个节点
思路1:遍历链表,假设有m个节点,倒数第n个等于m-n+1(正数),则问题转化为:删除第(m-n+1)个节点并输出头节点,n>m,则超出范围,n=m,删除节点,并返回头节点下一个节点。
思路2:双指针。l1,l2双指针,先让l1移动n个节点,两者再同时移动。l1移动到末尾,l2指的就是倒数第n个。
public ListNode removeNthFromEnd(ListNode head, int n) {
ListNode pre = new ListNode(0);
pre.next = head;
ListNode start = pre, end = pre;
while(n != 0) {
start = start.next;
n--;
}
while(start.next != null) {
start = start.next;
end = end.next;
}
end.next = end.next.next;
return pre.next;
}