给你两个链表 list1 和 list2 ,它们包含的元素分别为 n 个和 m 个。
请你将 list1 中下标从 a 到 b 的全部节点都删除,并将list2 接在被删除节点的位置。
下图中蓝色边和节点展示了操作后的结果:
请你返回结果链表的头指针。
?
?
示例 1:
输入:list1 = [0,1,2,3,4,5], a = 3, b = 4, list2 = [1000000,1000001,1000002] 输出:[0,1,2,1000000,1000001,1000002,5] 解释:我们删除 list1 中下标为 3 和 4 的两个节点,并将 list2 接在该位置。上图中蓝色的边和节点为答案链表。
?
示例 2:
输入:list1 = [0,1,2,3,4,5,6], a = 2, b = 5, list2 = [1000000,1000001,1000002,1000003,1000004] 输出:[0,1,1000000,1000001,1000002,1000003,1000004,6] 解释:上图中蓝色的边和节点为答案链表。
来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/merge-in-between-linked-lists 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
?题意是要在一个链表中删除一段并加入另一段
首先要知道删除的起始端和终点端
找到起始端和终点端后将起始端与另一段的起始端连接,再将终点端与另一段的终点端连接起来即可
class Solution {
public ListNode mergeInBetween(ListNode list1, int a, int b, ListNode list2) {
ListNode before = list1, after = list1;
//before代表前半段,after代表后半段
for (int i = 1; i < a; i++) {
before = before.next;
}
//从1到a-1遍历(一共a-1次)找到插入段的头部
for (int i = 0; i <= b; i++) {
after = after.next;
}
//从0到b遍历(一共b+1次)找到插入段的尾部
ListNode begin = list2, end = list2;
//begin代表list2的开始,end代表list2的结束
while (end.next != null) {
end = end.next;
}
//找到插入段的尾部,即第一个链表后半段的头部
before.next = begin;
end.next = after;
//收尾依次相连
return list1;
}
}
在题解中找到了更优的方法,比较发现,这种方法好在第二次找b节点后面的节点时直接以第一次找的a-1节点开始,省去了重复的步骤,时间短,占用内存少
class Solution {
public ListNode mergeInBetween(ListNode list1, int a, int b, ListNode list2) {
ListNode cur = list1;
int count = b - a + 2;
// 找到list1中第a个节点的前一个节点
while ((a - 1) > 0) {
a--;
cur = cur.next;
}
ListNode left = cur;
// 找到list1中第b个节点的后一个节点
while (count > 0) {
cur = cur.next;
count--;
}
ListNode right = cur;
// 将list1中第a个节点的前一个节点指向list2的头节点
left.next = list2;
// 找到list2的尾节点
while(list2.next != null) {
list2 = list2.next;
}
// 将list2的尾节点指向list1中第b个节点的后一个节点
list2.next = right;
return list1;
}
}
?
|